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