激情久久久_欧美视频区_成人av免费_不卡视频一二三区_欧美精品在欧美一区二区少妇_欧美一区二区三区的

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - Java教程 - Feign Client 超時時間配置不生效的解決

Feign Client 超時時間配置不生效的解決

2022-01-17 11:31[email protected] Java教程

這篇文章主要介紹了Feign Client 超時時間配置不生效的解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教

Feign Client 超時時間配置不生效

解決方案

Feign Client 的 connectTimeout 和 readTimeout 需要同時配置:

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

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

問題描述

Feign Client 配置如下:

?
1
2
3
feign.client.config.default.connectTimeout = 3000
feign.client.config.default.readTimeout = 3000
feign.client.config.my-api.readTimeout = 600000

默認超時時間配置了 3 秒。

由于 my-api 的響應數據較大,于是配置了 10 分鐘超時時間。

執行后發現,my-api 請求仍然 3 秒后就拋出如下異常:

?
1
2
3
4
5
6
7
8
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的各種超時時間設置

在Spring Cloud微服務架構中,大部分公司都是利用Open Feign進行服務間的調用,而比較簡單的業務使用默認配置是不會有多大問題的,但是如果是業務比較復雜,服務要進行比較繁雜的業務計算,那后臺很有可能會出現Read Timeout這個異常,因此定制化配置超時時間就有必要了。

1. Feign Client Configuration

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
# 默認開啟
feign.httpclient.enabled=false
# 默認關閉
feign.okhttp.enabled=true
# 默認關閉
feign.hystrix.enabled=false
# 默認關閉
feign.sentinel.enabled=true
# default context 連接超時時間
feign.client.config.default.connectTimeout = 5000
# default context 讀超時時間
feign.client.config.default.readTimeout = 10000
# 設置重試處理器,默認直接拋出異常
# feign.client.config.default.retryer = Class<Retryer>
# 設置日志級別,默認NONE
# feign.client.config.default.loggerLevel = FULL

2. Hystrix Configuration

?
1
2
# 全局設置超時:
hystrix.command.default.execution.isolation.thread.timeoutInMilliseconds: 30000

hystrix在ribbon的外層處理。

3. Ribbon Configuration

?
1
2
3
4
5
6
# 連接超時時間,默認為1秒,該值會被FeignClient配置connectTimeout覆蓋
ribbon.ConnectTimeout=5000
# 讀超時時間,默認為1秒,該值會被FeignClient配置readTimeout覆蓋
ribbon.ReadTimeout=5000
# 最大重試次數
ribbon.MaxAutoRetries=1

當Ribbon調用接口發送連接異常或者超時異常時會觸發Ribbon 的重試機制。

4. OkHttp Client Configuration

所設置的連接時間和超時時間最后會動態設置到OkHttpClient中,最底層也就是Socket的連接時間和讀超時時間。也就是說,直接配置OkHttpClient是無效的。

解決方案:添加OkHttp Client的請求Interceptor,動態設置超時時間。

?
1
2
3
4
5
6
7
8
9
10
11
12
@Bean("okHttpClient")
public OkHttpClient okHttpClient(ConnectionPool connectionPool) {
 return new OkHttpClient().newBuilder().connectionPool(connectionPool)
             // 改值在FeignClient體系中會被動態覆蓋
   .connectTimeout(6, TimeUnit.SECONDS)
             // 改值在FeignClient體系中會被動態覆蓋
   .readTimeout(VmcConstants.TEN_SECONDS, TimeUnit.SECONDS)
             // 添加攔截器,支持動態設置超時時間
   .addInterceptor(new OkHttpClientDynamicTimeoutInterceptor())
            .eventListener(eventListener())
   .build();
}

5. 小結一下吧

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

其實是有套路的,因為Feign的請求:其實是Hystrix+Ribbon。Hystrix在最外層,然后再到Ribbon,最后里面的是http請求。所以說。Hystrix的熔斷時間必須大于Ribbon的 ( ConnectTimeout + ReadTimeout )。而如果Ribbon開啟了重試機制,還需要乘以對應的重試次數,保證在Ribbon里的請求還沒結束時,Hystrix的熔斷時間不會超時。

Feign Client 超時時間配置不生效的解決

以上為個人經驗,希望能給大家一個參考,也希望大家多多支持服務器之家。

原文鏈接:https://blog.csdn.net/wu_weijie/article/details/112731675

延伸 · 閱讀

精彩推薦
  • Java教程升級IDEA后Lombok不能使用的解決方法

    升級IDEA后Lombok不能使用的解決方法

    最近看到提示IDEA提示升級,尋思已經有好久沒有升過級了。升級完畢重啟之后,突然發現好多錯誤,本文就來介紹一下如何解決,感興趣的可以了解一下...

    程序猿DD9332021-10-08
  • Java教程Java實現搶紅包功能

    Java實現搶紅包功能

    這篇文章主要為大家詳細介紹了Java實現搶紅包功能,采用多線程模擬多人同時搶紅包,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙...

    littleschemer13532021-05-16
  • Java教程小米推送Java代碼

    小米推送Java代碼

    今天小編就為大家分享一篇關于小米推送Java代碼,小編覺得內容挺不錯的,現在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧...

    富貴穩中求8032021-07-12
  • Java教程Java使用SAX解析xml的示例

    Java使用SAX解析xml的示例

    這篇文章主要介紹了Java使用SAX解析xml的示例,幫助大家更好的理解和學習使用Java,感興趣的朋友可以了解下...

    大行者10067412021-08-30
  • Java教程20個非常實用的Java程序代碼片段

    20個非常實用的Java程序代碼片段

    這篇文章主要為大家分享了20個非常實用的Java程序片段,對java開發項目有所幫助,感興趣的小伙伴們可以參考一下 ...

    lijiao5352020-04-06
  • Java教程Java BufferWriter寫文件寫不進去或缺失數據的解決

    Java BufferWriter寫文件寫不進去或缺失數據的解決

    這篇文章主要介紹了Java BufferWriter寫文件寫不進去或缺失數據的解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望...

    spcoder14552021-10-18
  • Java教程xml與Java對象的轉換詳解

    xml與Java對象的轉換詳解

    這篇文章主要介紹了xml與Java對象的轉換詳解的相關資料,需要的朋友可以參考下...

    Java教程網2942020-09-17
  • Java教程Java8中Stream使用的一個注意事項

    Java8中Stream使用的一個注意事項

    最近在工作中發現了對于集合操作轉換的神器,java8新特性 stream,但在使用中遇到了一個非常重要的注意點,所以這篇文章主要給大家介紹了關于Java8中S...

    阿杜7482021-02-04
主站蜘蛛池模板: xxxx69hd一hd | 成人乱人乱一区二区三区 | 国产精品久久久久久久久久10秀 | 国语自产免费精品视频在 | 亚洲福利视频52 | 日本a∨精品中文字幕在线 国产精品片www48888 | 久久久久九九九女人毛片 | 成人免费淫片视频观 | 主人在调教室性调教女仆游戏 | 欧美在线观看视频网站 | av在线影片 | 色污视频| 黄色大片在线观看 | 3级毛片 | 蜜桃成品人免费视频 | 一级黄色大片在线观看 | 黄色网电影 | 免费黄网站在线播放 | 日日操夜夜操视频 | 亚洲网站在线播放 | 在线免费观看日韩视频 | 欧美一级美国一级 | 亚洲综合91 | 久久久国产精品免费观看 | 国产精品久久国产精麻豆96堂 | 狠狠一区二区 | 国产精品成人久久久久a级 欧美特黄一级高清免费的香蕉 | 免费在线观看午夜视频 | 黄污网站在线 | 日本在线免费观看 | 免费黄色小视频网站 | 国产免费传媒av片在线 | 国产精品久久久不卡 | 黄色网址在线视频 | 国产一区精品在线观看 | 国产一区二区三区在线免费 | 欧美国产成人在线 | 欧美亚洲综合在线 | 日本一道aⅴ不卡免费播放 久久久久久久高清 | 91高清在线免费观看 | 精品一区二区久久久久久久网精 |