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

Feign Client 超時(shí)時(shí)間配置不生效的解決

 更新時(shí)間:2021年09月24日 11:03:54   作者:wuweijie@apache.org  
這篇文章主要介紹了Feign Client 超時(shí)時(shí)間配置不生效的解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

Feign Client 超時(shí)時(shí)間配置不生效

解決方案

Feign Client 的 connectTimeout 和 readTimeout 需要同時(shí)配置:

feign.client.config.my-api.connectTimeout = 10000
feign.client.config.my-api.readTimeout = 600000

如果只配置了 readTimeout 或 connectTimeout 的其中一條,配置不生效。

問題描述

Feign Client 配置如下:

feign.client.config.default.connectTimeout = 3000
feign.client.config.default.readTimeout = 3000
feign.client.config.my-api.readTimeout = 600000

默認(rèn)超時(shí)時(shí)間配置了 3 秒。

由于 my-api 的響應(yīng)數(shù)據(jù)較大,于是配置了 10 分鐘超時(shí)時(shí)間。

執(zhí)行后發(fā)現(xiàn),my-api 請(qǐng)求仍然 3 秒后就拋出如下異常:

Caused by: feign.RetryableException: Read timed out executing POST http://my-api
 at feign.FeignException.errorExecuting(FeignException.java:67)
 at feign.SynchronousMethodHandler.executeAndDecode(SynchronousMethodHandler.java:104)
 at feign.SynchronousMethodHandler.invoke(SynchronousMethodHandler.java:76)
 at feign.hystrix.HystrixInvocationHandler$1.run(HystrixInvocationHandler.java:108)
 at com.netflix.hystrix.HystrixCommand$2.call(HystrixCommand.java:302)
 at com.netflix.hystrix.HystrixCommand$2.call(HystrixCommand.java:298)
 at rx.internal.operators.OnSubscribeDefer.call(OnSubscribeDefer.java:46)

Feign Client的各種超時(shí)時(shí)間設(shè)置

在Spring Cloud微服務(wù)架構(gòu)中,大部分公司都是利用Open Feign進(jìn)行服務(wù)間的調(diào)用,而比較簡(jiǎn)單的業(yè)務(wù)使用默認(rèn)配置是不會(huì)有多大問題的,但是如果是業(yè)務(wù)比較復(fù)雜,服務(wù)要進(jìn)行比較繁雜的業(yè)務(wù)計(jì)算,那后臺(tái)很有可能會(huì)出現(xiàn)Read Timeout這個(gè)異常,因此定制化配置超時(shí)時(shí)間就有必要了。

1. Feign Client Configuration

# 默認(rèn)開啟
feign.httpclient.enabled=false
# 默認(rèn)關(guān)閉
feign.okhttp.enabled=true
# 默認(rèn)關(guān)閉
feign.hystrix.enabled=false
# 默認(rèn)關(guān)閉
feign.sentinel.enabled=true
# default context 連接超時(shí)時(shí)間
feign.client.config.default.connectTimeout = 5000
# default context 讀超時(shí)時(shí)間
feign.client.config.default.readTimeout = 10000
# 設(shè)置重試處理器,默認(rèn)直接拋出異常
# feign.client.config.default.retryer = Class<Retryer>
# 設(shè)置日志級(jí)別,默認(rèn)NONE
# feign.client.config.default.loggerLevel = FULL

2. Hystrix Configuration

# 全局設(shè)置超時(shí):
hystrix.command.default.execution.isolation.thread.timeoutInMilliseconds: 30000

hystrix在ribbon的外層處理。

3. Ribbon Configuration

# 連接超時(shí)時(shí)間,默認(rèn)為1秒,該值會(huì)被FeignClient配置connectTimeout覆蓋
ribbon.ConnectTimeout=5000
# 讀超時(shí)時(shí)間,默認(rèn)為1秒,該值會(huì)被FeignClient配置readTimeout覆蓋
ribbon.ReadTimeout=5000
# 最大重試次數(shù)
ribbon.MaxAutoRetries=1

當(dāng)Ribbon調(diào)用接口發(fā)送連接異?;蛘叱瑫r(shí)異常時(shí)會(huì)觸發(fā)Ribbon 的重試機(jī)制。

4. OkHttp Client Configuration

所設(shè)置的連接時(shí)間和超時(shí)時(shí)間最后會(huì)動(dòng)態(tài)設(shè)置到OkHttpClient中,最底層也就是Socket的連接時(shí)間和讀超時(shí)時(shí)間。也就是說,直接配置OkHttpClient是無效的。

解決方案:添加OkHttp Client的請(qǐng)求Interceptor,動(dòng)態(tài)設(shè)置超時(shí)時(shí)間。

@Bean("okHttpClient")
public OkHttpClient okHttpClient(ConnectionPool connectionPool) {
 return new OkHttpClient().newBuilder().connectionPool(connectionPool)
             // 改值在FeignClient體系中會(huì)被動(dòng)態(tài)覆蓋
   .connectTimeout(6, TimeUnit.SECONDS)
             // 改值在FeignClient體系中會(huì)被動(dòng)態(tài)覆蓋
   .readTimeout(VmcConstants.TEN_SECONDS, TimeUnit.SECONDS)
             // 添加攔截器,支持動(dòng)態(tài)設(shè)置超時(shí)時(shí)間
   .addInterceptor(new OkHttpClientDynamicTimeoutInterceptor())
            .eventListener(eventListener())
   .build();
}

5. 小結(jié)一下吧

1.如何配置好Hystrix和Ribbon的超時(shí)時(shí)間呢?

其實(shí)是有套路的,因?yàn)镕eign的請(qǐng)求:其實(shí)是Hystrix+Ribbon。Hystrix在最外層,然后再到Ribbon,最后里面的是http請(qǐng)求。所以說。Hystrix的熔斷時(shí)間必須大于Ribbon的 ( ConnectTimeout + ReadTimeout )。而如果Ribbon開啟了重試機(jī)制,還需要乘以對(duì)應(yīng)的重試次數(shù),保證在Ribbon里的請(qǐng)求還沒結(jié)束時(shí),Hystrix的熔斷時(shí)間不會(huì)超時(shí)。

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • 詳解Spring Boot中如何自定義SpringMVC配置

    詳解Spring Boot中如何自定義SpringMVC配置

    這篇文章主要給大家介紹了關(guān)于Spring Boot中如何自定義SpringMVC配置的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2021-09-09
  • Springboot如何使用@Async實(shí)現(xiàn)異步任務(wù)

    Springboot如何使用@Async實(shí)現(xiàn)異步任務(wù)

    這篇文章主要介紹了Springboot如何使用@Async實(shí)現(xiàn)異步任務(wù)問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-09-09
  • Java的原子類無鎖并發(fā)利器詳解

    Java的原子類無鎖并發(fā)利器詳解

    這篇文章主要介紹了Java的原子類無鎖并發(fā)利器詳解,原子類同樣能夠解決互斥性問題、原子性問題除此之外,因?yàn)樵宇愂菬o鎖操作,沒有用互斥鎖解決帶來的加鎖解決性能消耗,這種絕佳方案是怎么做到的呢,需要的朋友可以參考下
    2023-12-12
  • Hadoop集成Spring的使用詳細(xì)教程(快速入門大數(shù)據(jù))

    Hadoop集成Spring的使用詳細(xì)教程(快速入門大數(shù)據(jù))

    這篇文章主要介紹了Hadoop集成Spring的使用詳細(xì)教程(快速入門大數(shù)據(jù)),本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-01-01
  • idea配置springboot熱部署終極解決辦法(解決熱部署失效問題)

    idea配置springboot熱部署終極解決辦法(解決熱部署失效問題)

    這篇文章主要介紹了idea配置springboot熱部署終極解決辦法(解決熱部署失效問題),本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧
    2020-07-07
  • Java課設(shè)案例之百行代碼實(shí)現(xiàn)簡(jiǎn)易計(jì)算器

    Java課設(shè)案例之百行代碼實(shí)現(xiàn)簡(jiǎn)易計(jì)算器

    下面這篇文章主要給大家介紹了關(guān)于Java課設(shè)案例之百行代碼實(shí)現(xiàn)簡(jiǎn)易計(jì)算器的相關(guān)資料,這是一個(gè)關(guān)于java簡(jiǎn)單計(jì)算器的完整課程設(shè)計(jì)以及源碼,需要的朋友可以參考下
    2023-06-06
  • Spring中基于xml配置管理Bean的步驟

    Spring中基于xml配置管理Bean的步驟

    Spring容器通常理解為BeanFactory或者ApplicationContext,我們知道spring的IOC容器能夠幫我們創(chuàng)建對(duì)象,對(duì)象交給spring管理之后我們就不用手動(dòng)去new對(duì)象,這篇文章主要介紹了Spring中基于xml配置管理Bean的步驟,需要的朋友可以參考下
    2023-11-11
  • mybatisplus駝峰命名映射的問題解決

    mybatisplus駝峰命名映射的問題解決

    本文主要介紹了mybatisplus駝峰命名映射的問題解決,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-07-07
  • Java集合中的LinkedHashSet源碼解讀

    Java集合中的LinkedHashSet源碼解讀

    這篇文章主要介紹了Java集合中的LinkedHashSet源碼解讀,在LinkedHashMap中,雙向鏈表的遍歷順序通過構(gòu)造方法指定,如果沒有指定,則使用默認(rèn)順序?yàn)椴迦腠樞?即accessOrder=false,需要的朋友可以參考下
    2023-12-12
  • 關(guān)于為何說JAVA中要慎重使用繼承詳解

    關(guān)于為何說JAVA中要慎重使用繼承詳解

    Java繼承是面向?qū)ο蟮淖铒@著的一個(gè)特征,然而下面這篇文章主要給大家介紹了關(guān)于為何說JAVA中要慎重使用繼承的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考借鑒,下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2018-08-08

最新評(píng)論