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

基于Feign實現異步調用

 更新時間:2021年05月14日 09:35:11   作者:努力的小星星  
近期,需要對之前的接口進行優(yōu)化,縮短接口的響應時間,但是springcloud中的feign是不支持傳遞異步化的回調結果的,因此有了以下的解決方案,記錄一下,需要的朋友可以參考下

一、背景

希望將http的調用由同步等待改為異步,仍使用feign的便捷。

二、使用feign理由

本質上其實feign就是將httpclient常用的操作進行簡單封裝,且屏蔽底層的httpclient,無感知具體的client實現,輕松完成具體client的替換

三、解決方案

feign在10.8版本后提供了Async接口,如下:

四、demo代碼實現

4.1 接口編寫

public interface OriginFeignClient {

    @RequestLine("POST /async/server/api")

    CompletableFuture<String> api(@Param("param") String param);

}

4.2 接口發(fā)布

@Configuration

public class OriginFeignClientConfig {

    @Bean

    public SpringEncoder springEncoder(ObjectFactory<HttpMessageConverters> messageConverters) {

        return new SpringEncoder(messageConverters);

    }

    @Bean

    public SpringDecoder springDecoder(ObjectFactory<HttpMessageConverters> messageConverters) {

        return new SpringDecoder(messageConverters);

    }

    @Bean

    public OriginFeignClient originFeignClient(SpringEncoder springEncoder, SpringDecoder springDecoder) {

        return AsyncFeign.asyncBuilder()

                .encoder(springEncoder)

                .decoder(springDecoder)

                .target(OriginFeignClient.class, "http://localhost.charlesproxy.com:8090");

    }

}

4.3 調用

@GetMapping("testApi")

    public String testAsyncClient() throws ExecutionException, InterruptedException {

        List<CompletableFuture<String>> results = new ArrayList<>();

        for(int i = 0; i < 10; i++) {

            results.add(originFeignClient.api(i+""));

        }

        Thread.sleep(3000);

        int index = 0;

        for (CompletableFuture<String> result : results) {

            String str = result.get();

            log.info(String.format("%d, result:%s, ", index, str));

            index++;

        }

        return "success";

    }

4.4 結果(很明顯,是異步調用)

2021-05-11 14:31:29.989 - INFO [TraceId: , SpanId : ] 24745 --- [nio-8091-exec-5] c.m.a.c.controller.ClientController : 0, result:receive: {"param":"0"} at 2021-05-11 02:31:27.243,

2021-05-11 14:31:29.993 - INFO [TraceId: , SpanId : ] 24745 --- [nio-8091-exec-5] c.m.a.c.controller.ClientController : 1, result:receive: {"param":"1"} at 2021-05-11 02:31:27.243,

2021-05-11 14:31:29.995 - INFO [TraceId: , SpanId : ] 24745 --- [nio-8091-exec-5] c.m.a.c.controller.ClientController : 2, result:receive: {"param":"2"} at 2021-05-11 02:31:27.244,

2021-05-11 14:31:29.995 - INFO [TraceId: , SpanId : ] 24745 --- [nio-8091-exec-5] c.m.a.c.controller.ClientController : 3, result:receive: {"param":"3"} at 2021-05-11 02:31:27.245,

2021-05-11 14:31:29.995 - INFO [TraceId: , SpanId : ] 24745 --- [nio-8091-exec-5] c.m.a.c.controller.ClientController : 4, result:receive: {"param":"4"} at 2021-05-11 02:31:27.243,

2021-05-11 14:31:29.996 - INFO [TraceId: , SpanId : ] 24745 --- [nio-8091-exec-5] c.m.a.c.controller.ClientController : 5, result:receive: {"param":"5"} at 2021-05-11 02:31:27.243,

2021-05-11 14:31:29.996 - INFO [TraceId: , SpanId : ] 24745 --- [nio-8091-exec-5] c.m.a.c.controller.ClientController : 6, result:receive: {"param":"6"} at 2021-05-11 02:31:27.244,

2021-05-11 14:31:29.997 - INFO [TraceId: , SpanId : ] 24745 --- [nio-8091-exec-5] c.m.a.c.controller.ClientController : 7, result:receive: {"param":"7"} at 2021-05-11 02:31:27.243,

2021-05-11 14:31:29.997 - INFO [TraceId: , SpanId : ] 24745 --- [nio-8091-exec-5] c.m.a.c.controller.ClientController : 8, result:receive: {"param":"8"} at 2021-05-11 02:31:27.244,

2021-05-11 14:31:29.998 - INFO [TraceId: , SpanId : ] 24745 --- [nio-8091-exec-5] c.m.a.c.controller.ClientController : 9, result:receive: {"param":"9"} at 2021-05-11 02:31:27.245,

 五、問題

feign增加的async實現是10.8版本,我們找到Spring boot 2.2.13和相應cloud最新版Hoxton.SR11(當然不是最新,是該小版本下最新,因為目前項目中使用的就是該版本),排查思路就是以@EnableFeignClients為入口

1.EnableFeignClients內容如下

@Import(FeignClientsRegistrar.class)
public @interface EnableFeignClients {
}

引入了FeignClientsRegistrar

2.FeignClientsRegistrar功能如下:

(1)掃描@FeignClient,并將其下入到BeanDefinition中

(2)調用registerFeignClient,構造FeignClientFactoryBean(創(chuàng)建feign的工廠類,關鍵在此

(3)進入FeignClientFactoryBean內部看下,構建feign的方法:getTarget():

從context中去找feign.Feign.Builder的實現(即@Bean),看下當前項目中有哪幾種實現:

1.org.springframework.cloud.openfeign.FeignCircuitBreaker.Builder Spring Cloud定義的通用斷路器

2.feign.hystrix.HystrixFeign.Builder 斷路器的原生實現

先不管哪種builder,最終執(zhí)行:loadBalance,方法內容如下:

protected <T> T loadBalance(Feign.Builder builder, FeignContext context,
		HardCodedTarget<T> target) {
	Client client = getOptional(context, Client.class);
	if (client != null) {
		builder.client(client);
		Targeter targeter = get(context, Targeter.class);
		return targeter.target(this, builder, context, target);
	}
 
	throw new IllegalStateException(
			"No Feign Client for loadBalancing defined. Did you forget to include spring-cloud-starter-netflix-ribbon?");
}

 好了??!看到我們想要的了,Client的創(chuàng)建,不對,等等??!Client,我們先看下他的實現類是不是包含我們的AsyncClient,

一切幻想破滅

好了,所以目前的Spring cloud openfeign中仍未支持該特性,先這樣用吧

到此這篇關于基于Feign實現異步調用的文章就介紹到這了,更多相關Feign異步調用內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • Hibernate的Session_flush與隔離級別代碼詳解

    Hibernate的Session_flush與隔離級別代碼詳解

    這篇文章主要介紹了Hibernate的Session_flush與隔離級別代碼詳解,分享了相關代碼示例,小編覺得還是挺不錯的,具有一定借鑒價值,需要的朋友可以參考下
    2018-02-02
  • Android實現兼容的水波紋效果

    Android實現兼容的水波紋效果

    Android的水波紋效果只有高版本才有,我們希望自己的應用在低版本用低版本的陰影,而高版本用水波紋,這怎么做呢?下面一起來學習學習。
    2016-08-08
  • 微服務中使用Maven BOM來管理你的版本依賴詳解

    微服務中使用Maven BOM來管理你的版本依賴詳解

    這篇文章主要介紹了微服務中使用Maven BOM來管理你的版本依賴,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-12-12
  • 深入淺出講解Java比較器及數學常用類

    深入淺出講解Java比較器及數學常用類

    這篇文章主要介紹了深入淺出講解Java比較器及數學常用類,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-09-09
  • 淺談Java數值類型的轉換與強制轉換

    淺談Java數值類型的轉換與強制轉換

    這篇文章主要介紹了Java數值類型的轉換與強制轉換,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-04-04
  • java中將list用逗號隔開拼成字符串的4種方法例子

    java中將list用逗號隔開拼成字符串的4種方法例子

    我們經常在開發(fā)過程之中會遇到需要把返回的Id list轉換為一個使用逗號(,)分隔的字符串,下面這篇文章主要給大家介紹了關于java中將list用逗號隔開拼成字符串的4種方法例子,需要的朋友可以參考下
    2024-01-01
  • java實現的連接數據庫及模糊查詢功能示例

    java實現的連接數據庫及模糊查詢功能示例

    這篇文章主要介紹了java實現的連接數據庫及模糊查詢功能,結合實例形式分析了java基于jdbc連接數據庫及使用LIKE語句實現模糊查詢功能的相關操作技巧,需要的朋友可以參考下
    2017-12-12
  • Java算法之時間復雜度和空間復雜度的概念和計算

    Java算法之時間復雜度和空間復雜度的概念和計算

    這篇文章主要介紹了Java算法之時間復雜度和空間復雜度的概念和計算,文中有非常詳細的代碼示例,對正在學習java的小伙伴們有非常好的幫助,需要的朋友可以參考下
    2021-05-05
  • Java 是如何利用接口避免函數回調的方法

    Java 是如何利用接口避免函數回調的方法

    本篇文章主要介紹了Java 是如何利用接口避免函數回調的方法,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-02-02
  • Java使用poi將word轉換為html

    Java使用poi將word轉換為html

    這篇文章主要為大家詳細介紹了Java使用poi將word轉換為html的相關資料,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-12-12

最新評論