Dubbo異步調(diào)用的實現(xiàn)介紹
前言
Dubbo不只提供了堵塞式的的同步調(diào)用,同時提供了異步調(diào)用的方式。這種方式主要應(yīng)用于提供者接口響應(yīng)耗時明顯,消費(fèi)者端可以利用調(diào)用接口的時間去做一些其他的接口調(diào)用,利用Future 模式來異步等待和獲取結(jié)果即可。這種方式可以大大的提升消費(fèi)者端的利用率。 目前這種方式可以通過XML的方式進(jìn)行引入。
1、異步調(diào)用實現(xiàn)
(1)為了能夠模擬等待,通過 int timeToWait參數(shù),標(biāo)明需要休眠多少毫秒后才會進(jìn)行返回。
String sayHello(String name, int timeToWait);
(2)接口實現(xiàn) 為了模擬調(diào)用耗時 可以讓線程等待一段時間
(3)在消費(fèi)者端,配置異步調(diào)用 注意消費(fèi)端默認(rèn)超時時間1000毫秒 如果提供端耗時大于1000毫秒會出現(xiàn)超時
可以通過改變消費(fèi)端的超時時間 通過timeout屬性設(shè)置即可單位毫秒
<dubbo:reference id="helloService" interface="com.lagou.service.HelloService"> <!--添加異步調(diào)用方式,注解方式不支持--> <dubbo:method name="sayHello" async="true" /> </dubbo:reference>
(4)測試,我們休眠100毫秒,然后再去進(jìn)行獲取結(jié)果。方法在同步調(diào)用時的返回值是空,我們可以通過RpcContext.getContext().getFuture() 來進(jìn)行獲取Future對象來進(jìn)行后續(xù)的結(jié)果等待操作。
package com.lagou; import com.lagou.bean.ConsumerComponent; import com.lagou.service.HelloService; import com.sun.org.apache.xpath.internal.functions.FuncTrue; import org.apache.dubbo.rpc.RpcContext; import org.springframework.context.support.ClassPathXmlApplicationContext; import java.io.IOException; import java.util.concurrent.Future; public class XMLConsumerMain { public static void main(String[] args) throws IOException, InterruptedException { ClassPathXmlApplicationContext app = new ClassPathXmlApplicationContext("consumer.xml"); HelloService service = app.getBean(HelloService.class); while (true) { System.in.read(); try { String hello = service.sayHello("world", 100); // 利用Future 模式來獲取 Future<Object> future = RpcContext.getContext().getFuture(); System.out.println("result :" + hello); System.out.println("future result:"+future.get()); } catch (Exception e) { e.printStackTrace(); } } } }
2、異步調(diào)用特殊說明
需要特別說明的是,該方式的使用,請確保dubbo的版本在2.5.4及以后的版本使用。 原因在于在2.5.3及之前的版本使用的時候,會出現(xiàn)異步狀態(tài)傳遞問題。
比如我們的服務(wù)調(diào)用關(guān)系是A -> B -> C , 這時候如果A向B發(fā)起了異步請求,在錯誤的版本時,B向C發(fā)起的請求也會連帶的產(chǎn)生異步請求。這是因為在底層實現(xiàn)層面,他是通過RPCContext 中的attachment 實現(xiàn)的。在A向B發(fā)起異步請求時,會在attachment 中增加一個異步標(biāo)示字段來表明異步等待結(jié)果。B在接受到A中的請求時,會通過該字段來判斷是否是異步處理。但是由于值傳遞問題,B向C發(fā)起時同樣會將該值進(jìn)行傳遞,導(dǎo)致C誤以為需要異步結(jié)果,導(dǎo)致返回空。這個問題在2.5.4及以后的版本進(jìn)行了修正。
到此這篇關(guān)于Dubbo異步調(diào)用的實現(xiàn)介紹的文章就介紹到這了,更多相關(guān)Dubbo異步調(diào)用內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
java開發(fā)微服務(wù)架構(gòu)設(shè)計消息隊列的水有多深
今天我們說說消息隊列的問題,來帶大家探一探消息隊列的水有多深,希望看完本文大家在引入消息隊列的時候先想一想,是不是一定要引入?引入消息隊列后產(chǎn)生的問題能不能解決2021-10-10Java Optional<Foo>轉(zhuǎn)換成List<Bar>的實例方法
在本篇內(nèi)容里小編給大家整理的是一篇關(guān)于Java Optional<Foo>轉(zhuǎn)換成List<Bar>的實例方法,有需要的朋友們可以跟著學(xué)習(xí)下。2021-06-06淺談SpringCloud feign的http請求組件優(yōu)化方案
這篇文章主要介紹了淺談SpringCloud feign的http請求組件優(yōu)化方案,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2021-02-02Java中網(wǎng)絡(luò)IO的實現(xiàn)方式(BIO、NIO、AIO)介紹
這篇文章主要介紹了Java中網(wǎng)絡(luò)IO的實現(xiàn)方式(BIO、NIO、AIO)介紹的相關(guān)資料,需要的朋友可以參考下2017-03-03SpringBoot實戰(zhàn)記錄之?dāng)?shù)據(jù)訪問
對于數(shù)據(jù)訪問層,無論是SQL還是NOSQL,Spring Boot默認(rèn)采用整合Spring Data的方式進(jìn)行統(tǒng)一處理,添加大量自動配置,屏蔽了很多設(shè)置,下面這篇文章主要介紹了SpringBoot實戰(zhàn)記錄之?dāng)?shù)據(jù)訪問,需要的朋友可以參考下2022-04-04spring cloud consul注冊的服務(wù)報錯critical的解決
這篇文章主要介紹了spring cloud consul注冊的服務(wù)報錯critical的解決,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2019-03-03Java ScheduledExecutorService定時任務(wù)案例講解
這篇文章主要介紹了Java ScheduledExecutorService定時任務(wù)案例講解,本篇文章通過簡要的案例,講解了該項技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-08-08