Feign Client 超時時間配置不生效的解決
Feign Client 超時時間配置不生效
解決方案
Feign Client 的 connectTimeout 和 readTimeout 需要同時配置:
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
默認超時時間配置了 3 秒。
由于 my-api 的響應(yīng)數(shù)據(jù)較大,于是配置了 10 分鐘超時時間。
執(zhí)行后發(fā)現(xiàn),my-api 請求仍然 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è)置
在Spring Cloud微服務(wù)架構(gòu)中,大部分公司都是利用Open Feign進行服務(wù)間的調(diào)用,而比較簡單的業(yè)務(wù)使用默認配置是不會有多大問題的,但是如果是業(yè)務(wù)比較復(fù)雜,服務(wù)要進行比較繁雜的業(yè)務(wù)計算,那后臺很有可能會出現(xiàn)Read Timeout這個異常,因此定制化配置超時時間就有必要了。
1. Feign Client Configuration
# 默認開啟 feign.httpclient.enabled=false # 默認關(guān)閉 feign.okhttp.enabled=true # 默認關(guān)閉 feign.hystrix.enabled=false # 默認關(guān)閉 feign.sentinel.enabled=true # default context 連接超時時間 feign.client.config.default.connectTimeout = 5000 # default context 讀超時時間 feign.client.config.default.readTimeout = 10000 # 設(shè)置重試處理器,默認直接拋出異常 # feign.client.config.default.retryer = Class<Retryer> # 設(shè)置日志級別,默認NONE # feign.client.config.default.loggerLevel = FULL
2. Hystrix Configuration
# 全局設(shè)置超時: hystrix.command.default.execution.isolation.thread.timeoutInMilliseconds: 30000
hystrix在ribbon的外層處理。
3. Ribbon Configuration
# 連接超時時間,默認為1秒,該值會被FeignClient配置connectTimeout覆蓋 ribbon.ConnectTimeout=5000 # 讀超時時間,默認為1秒,該值會被FeignClient配置readTimeout覆蓋 ribbon.ReadTimeout=5000 # 最大重試次數(shù) ribbon.MaxAutoRetries=1
當Ribbon調(diào)用接口發(fā)送連接異?;蛘叱瑫r異常時會觸發(fā)Ribbon 的重試機制。
4. OkHttp Client Configuration
所設(shè)置的連接時間和超時時間最后會動態(tài)設(shè)置到OkHttpClient中,最底層也就是Socket的連接時間和讀超時時間。也就是說,直接配置OkHttpClient是無效的。
解決方案:添加OkHttp Client的請求Interceptor,動態(tài)設(shè)置超時時間。
@Bean("okHttpClient") public OkHttpClient okHttpClient(ConnectionPool connectionPool) { return new OkHttpClient().newBuilder().connectionPool(connectionPool) // 改值在FeignClient體系中會被動態(tài)覆蓋 .connectTimeout(6, TimeUnit.SECONDS) // 改值在FeignClient體系中會被動態(tài)覆蓋 .readTimeout(VmcConstants.TEN_SECONDS, TimeUnit.SECONDS) // 添加攔截器,支持動態(tài)設(shè)置超時時間 .addInterceptor(new OkHttpClientDynamicTimeoutInterceptor()) .eventListener(eventListener()) .build(); }
5. 小結(jié)一下吧
1.如何配置好Hystrix和Ribbon的超時時間呢?
其實是有套路的,因為Feign的請求:其實是Hystrix+Ribbon。Hystrix在最外層,然后再到Ribbon,最后里面的是http請求。所以說。Hystrix的熔斷時間必須大于Ribbon的 ( ConnectTimeout + ReadTimeout )。而如果Ribbon開啟了重試機制,還需要乘以對應(yīng)的重試次數(shù),保證在Ribbon里的請求還沒結(jié)束時,Hystrix的熔斷時間不會超時。
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
詳解Spring Boot中如何自定義SpringMVC配置
這篇文章主要給大家介紹了關(guān)于Spring Boot中如何自定義SpringMVC配置的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2021-09-09Springboot如何使用@Async實現(xiàn)異步任務(wù)
這篇文章主要介紹了Springboot如何使用@Async實現(xiàn)異步任務(wù)問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2023-09-09Hadoop集成Spring的使用詳細教程(快速入門大數(shù)據(jù))
這篇文章主要介紹了Hadoop集成Spring的使用詳細教程(快速入門大數(shù)據(jù)),本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-01-01idea配置springboot熱部署終極解決辦法(解決熱部署失效問題)
這篇文章主要介紹了idea配置springboot熱部署終極解決辦法(解決熱部署失效問題),本文通過實例代碼給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友參考下吧2020-07-07Java課設(shè)案例之百行代碼實現(xiàn)簡易計算器
下面這篇文章主要給大家介紹了關(guān)于Java課設(shè)案例之百行代碼實現(xiàn)簡易計算器的相關(guān)資料,這是一個關(guān)于java簡單計算器的完整課程設(shè)計以及源碼,需要的朋友可以參考下2023-06-06