一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

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

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
主站蜘蛛池模板: 欧美xxx000喷水 | 成人欧美一区二区三区白人 | 希岛爱理作品在线观看 | 性一交一无一伦一精一品 | 国产精品天天看特色大片不卡 | 波多野结衣在线看 | 欧美三级做爰全过程 | 成人资源影音先锋久久资源网 | 欧美一区二区三区免费高 | 荡女人人爱 | 亚洲欧美日韩另类在线 | 国产成人h综合亚洲欧美在线 | 大学生按摩黄a级中文片 | 欧美高清在线精品一区 | 黄色a | 色呦呦tv| 久久99精品国产免费观看 | 日本视频免费在线 | 色亚洲视频 | 精品国产乱码久久久久久免费流畅 | 国产欧美成人免费观看 | 日产乱码2021永久手机版 | 亚洲国产在线 | 荷兰精品女人性hd | 欧美一级欧美三级在线 | 久久黄色免费 | 久久久精品免费免费直播 | 国产精品天天看天天爽 | 亚洲精品欧洲久久婷婷99 | 久久久无码精品亚洲欧美 | 欧美高清在线不卡免费观看 | 日本三级大学生17 | 免费日批软件 | 国产欧美综合精品一区二区 | 日韩免费视频一区 | 日韩欧美不卡视频 | 成年人黄视频在线观看 | 久久99国产视频 | 五月最新女厕所高跟嘘嘘 | 色哟约 | 欧美另类z0zxi|