Feign客戶端消費服務超時:com.netflix.hystrix.exception.HystrixRuntimeException:timed-out and fallback failed.

一. 背景

在微服務項目中,我的服務消費使用的是Feign客戶端,在調用服務提供者提供的接口時,報超時異常了,異常如下:

com.netflix.hystrix.exception.HystrixRuntimeException: RemoteCardImgHandleFeign#getVehicleLicenseInfos(CardInfosVi) timed-out and fallback failed.

在這裏插入圖片描述

二. Feign設置超時時間

1.使用Feign調用接口分兩層,ribbon的調用和hystrix的調用,所以ribbon的超時時間和Hystrix的超時時間的結合就是Feign的超時時間
2. 一般情況下 都是 ribbon的超時時間(<)hystrix的超時時間(因爲涉及到ribbon的重試機制),如果ribbon 的超時時間大於hystrix的超時時間,對於ribbon的重試是沒有意義的(hystrix超時熔斷了,ribbon無法重試)
在這裏插入圖片描述

三. 原因

Hystrix組件缺省超時判斷默認爲1秒鐘,超過1秒就會報超時異常日誌,由於我的服務器是在Linux環境,網絡延遲非常大,雖然已經把超時設置成了5秒,但是還是短了,可以將超時再設置長一點。

四. 解決方式

hystrix的默認超時1秒直接改成10秒,由於我的測試環境網絡延遲很慢,5秒還是不夠,直接設置成10秒

  • application.yml
##feign中使用斷路器Hystrix,默認是沒有開啓的,需要開啓
feign:
  hystrix:
    enabled: true
#hystrix的超時時間    
hystrix:
  command:
    default:
      execution:
        timeout:
          enabled: true
        isolation:
          thread:
            #設置請求超時時間,默認1秒,超過指定的時間後,觸發服務熔斷
            timeoutInMilliseconds: 10000
#ribbon的超時時間
ribbon:
  ReadTimeout: 5000 #設置請求處理的超時時間
  ConnectTimeout: 5000  #設置請求鏈接的超時時間                     

五. 另外兩種解決方式(未測試過,僅供參考)

下面兩種方式是比較暴力的一種解決方式,但在實際項目中並不推薦,對服務高可用存在一定的影響,兩種我沒有測試,還是推薦使用上面第一種

  • 第一種: 禁用Hystrix的請求時間超時限制
#hystrix的超時時間    
hystrix:
  command:
    default:
      execution:
        timeout:
          enabled: false
  • 第二種: 禁用feignhystrix
feign:
  hystrix:
    enabled: false
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章