欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Dubbo異步調(diào)用的實(shí)現(xiàn)介紹

 更新時(shí)間:2022年09月02日 17:05:08   作者:悠然予夏  
dubbo默認(rèn)使用同步的方式調(diào)用。但在有些特殊的場(chǎng)景下,我們可能希望異步調(diào)用dubbo接口,從而避免不必要的等待時(shí)間,這時(shí)候我們就需要用到異步。那么dubbo的異步是如何實(shí)現(xiàn)的呢?下面就來(lái)看看這個(gè)問(wè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ì)列的水有多深

    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-10
  • Java Optional<Foo>轉(zhuǎn)換成List<Bar>的實(shí)例方法

    Java Optional<Foo>轉(zhuǎn)換成List<Bar>的實(shí)例方法

    在本篇內(nèi)容里小編給大家整理的是一篇關(guān)于Java Optional<Foo>轉(zhuǎn)換成List<Bar>的實(shí)例方法,有需要的朋友們可以跟著學(xué)習(xí)下。
    2021-06-06
  • Java打包工具jar包詳解

    Java打包工具jar包詳解

    這篇文章主要介紹了Java打包工具jar包詳解,在本例中我們引入一個(gè)叫jaxen.jar的庫(kù),并將所有以”org.jaxen”開頭的類重命名以”org.example.jaxen”開頭,具體實(shí)例代碼跟隨小編一起看看吧
    2021-10-10
  • 淺談SpringCloud feign的http請(qǐng)求組件優(yōu)化方案

    淺談SpringCloud feign的http請(qǐng)求組件優(yōu)化方案

    這篇文章主要介紹了淺談SpringCloud feign的http請(qǐng)求組件優(yōu)化方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2021-02-02
  • 詳細(xì)解讀spring中的@Resource注解

    詳細(xì)解讀spring中的@Resource注解

    這篇文章主要介紹了詳細(xì)解讀spring中的@Resource注解,此注解來(lái)源于JSR規(guī)范(Java?Specification?Requests),其作用是找到依賴的組件注入到應(yīng)用來(lái),它利用了JNDI技術(shù)查找所需的資源,需要的朋友可以參考下
    2023-10-10
  • Java中網(wǎng)絡(luò)IO的實(shí)現(xiàn)方式(BIO、NIO、AIO)介紹

    Java中網(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-03
  • SpringBoot實(shí)戰(zhàn)記錄之?dāng)?shù)據(jù)訪問(wèn)

    SpringBoot實(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-04
  • spring cloud consul注冊(cè)的服務(wù)報(bào)錯(cuò)critical的解決

    spring 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-03
  • SpringSecurity解決POST方式下CSRF問(wèn)題

    SpringSecurity解決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-07
  • Java ScheduledExecutorService定時(shí)任務(wù)案例講解

    Java ScheduledExecutorService定時(shí)任務(wù)案例講解

    這篇文章主要介紹了Java ScheduledExecutorService定時(shí)任務(wù)案例講解,本篇文章通過(guò)簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下
    2021-08-08

最新評(píng)論