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

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

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

    java開發(fā)微服務(wù)架構(gòu)設(shè)計消息隊列的水有多深

    今天我們說說消息隊列的問題,來帶大家探一探消息隊列的水有多深,希望看完本文大家在引入消息隊列的時候先想一想,是不是一定要引入?引入消息隊列后產(chǎn)生的問題能不能解決
    2021-10-10
  • Java Optional<Foo>轉(zhuǎn)換成List<Bar>的實例方法

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

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

    Java打包工具jar包詳解

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

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

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

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

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

    Java中網(wǎng)絡(luò)IO的實現(xiàn)方式(BIO、NIO、AIO)介紹

    這篇文章主要介紹了Java中網(wǎng)絡(luò)IO的實現(xiàn)方式(BIO、NIO、AIO)介紹的相關(guān)資料,需要的朋友可以參考下
    2017-03-03
  • SpringBoot實戰(zhàn)記錄之?dāng)?shù)據(jù)訪問

    SpringBoot實戰(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-04
  • spring cloud consul注冊的服務(wù)報錯critical的解決

    spring cloud consul注冊的服務(wù)報錯critical的解決

    這篇文章主要介紹了spring cloud consul注冊的服務(wù)報錯critical的解決,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2019-03-03
  • SpringSecurity解決POST方式下CSRF問題

    SpringSecurity解決POST方式下CSRF問題

    本文主要介紹了SpringSecurity解決POST方式下CSRF問題,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-07-07
  • Java ScheduledExecutorService定時任務(wù)案例講解

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

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

最新評論