溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何解決springcloud中Feign超時的問題

發布時間:2021-06-24 10:52:55 來源:億速云 閱讀:496 作者:chen 欄目:開發技術

這篇文章主要講解了“如何解決springcloud中Feign超時的問題”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“如何解決springcloud中Feign超時的問題”吧!

問題背景

最近公司項目有個功能需進行三層Feign調用,且還要調外部接口,延遲挺大,造成Feign一直提示Read timed out executing POST。

feign.RetryableException: Read timed out executing POST http://******
        at feign.FeignException.errorExecuting(FeignException.java:67)
        at feign.SynchronousMethodHandler.executeAndDecode(SynchronousMethodHandler.java:104)
        at feign.SynchronousMethodHandler.invoke(SynchronousMethodHandler.java:76)
        at feign.ReflectiveFeign$FeignInvocationHandler.invoke(ReflectiveFeign.java:103)
        at com.sun.proxy.$Proxy113.getBaseRow(Unknown Source)
Caused by: java.net.SocketTimeoutException: Read timed out
        at java.net.SocketInputStream.socketRead0(Native Method)
        at java.net.SocketInputStream.socketRead(SocketInputStream.java:116)
        at java.net.SocketInputStream.read(SocketInputStream.java:170)
        at java.net.SocketInputStream.read(SocketInputStream.java:141)
        at java.io.BufferedInputStream.fill(BufferedInputStream.java:246)
        at java.io.BufferedInputStream.read1(BufferedInputStream.java:286)
        at java.io.BufferedInputStream.read(BufferedInputStream.java:345)
        at sun.net.www.http.HttpClient.parseHTTPHeader(HttpClient.java:704)
        at sun.net.www.http.HttpClient.parseHTTP(HttpClient.java:647)
        at sun.net.www.protocol.http.HttpURLConnection.getInputStream0(HttpURLConnection.java:1569)
        at sun.net.www.protocol.http.HttpURLConnection.getInputStream(HttpURLConnection.java:1474)
        at java.net.HttpURLConnection.getResponseCode(HttpURLConnection.java:480)
        at feign.Client$Default.convertResponse(Client.java:152)
        at feign.Client$Default.execute(Client.java:74)

解決方案

首先,我們看下Feign的簡介

Feign 是一個聲明式的web服務客戶端,這便得編寫web服務客戶端更容易,使用Feign 創建一個接口并對它進行注解,它具有可插拔的注解支持包括Feign注解與JAX-RS注解,Feign還支持可插拔的編碼器與解碼器,Spring Cloud 增加了對 Spring MVC的注解,Spring Web 默認使用了HttpMessageConverters, Spring Cloud 集成 Ribbon 和 Eureka 提供的負載均衡的HTTP客戶端 Feign.

這么說吧,Feign接口調用分兩層,Ribbon的調用和Hystrix調用,理論上設置Ribbon的時間即可,但是Ribbon的超時時間和Hystrix的超時時間需要結合起來,按照木桶原則最低的就是Feign的超時時間,建議最好配置超時時間一致。經過配置一下application設置后,完美解決了問題。因為第三方接口中需要3~20秒不等的時間,所以這個數值也是根據自己的業務系統情況設置的。

application.xml

#hystrix的超時時間
hystrix:
    command:
        default:
            execution:
              timeout:
                enabled: true
              isolation:
                    thread:
                        timeoutInMilliseconds: 30000
#ribbon的超時時間
ribbon:
  ReadTimeout: 30000
  ConnectTimeout: 30000

springcloud之Feign 負載均衡請求超時時間

SpringCloud:Greenwich.SR4

SpringBoot:2.1.9.RELEASE

Feign調用服務的默認時長是1秒鐘,也就是如果超過1秒沒連接上或者超過1秒沒響應,那么會相應的報錯。

但是在實際的業務中,我們的服務可能因為特別原因(網絡、處理壓力大等)導致相應速度超過1秒鐘,那么就會報錯,下面我們就來處理如何手動配置Feigin的負載均衡超時等參數

全局配置

SpringCloud負載均衡底層用的就是Ribbon

#--------------Feign負載均衡配置 配置全局超時時間
ribbon:
  ConnectTimeout: 5000 #請求連接的超時時間,默認時間為1秒
  ReadTimeout: 5000 #請求處理的超時時間

5秒沒有響應成功就報如下錯誤(真實情況下,會比5s多一些,因為發送請求也需要時間的,模擬超時可以在請求處理的方法上用Thread.sleep()設置休眠時間超過5s)

如何解決springcloud中Feign超時的問題

局部配置(就是指定提供者)

#--------------Feign負載均衡配置 局部配置超時時間等
feign-product-provider: #指定配置的服務名稱
  ribbon:
    OkToRetryOnAllOperations: true # 對所有請求都進行重試
    MaxAutoRetries: 2 # 對當前實例的重試次數
    MaxAutoRetriesNextServer: 0 # 切換實例的重試次數(集群狀態下,其它對其它實例服務重試的次數)
    ConnectTimeout: 3000 # 請求連接的超時時間
    ReadTimeout: 3000 # 請求處理的超時時間

上述提到的服務名稱如下配置

spring:
  application:
    name: feign-product-provider # 隨意設置

執行的代碼

如何解決springcloud中Feign超時的問題

輸出結果

如何解決springcloud中Feign超時的問題

不是一共重試兩次嗎?這里邊就涉及到了一個公式

共重試次數 = (MaxAutoRetries+MaxAutoRetriesNextServer+(MaxAutoRetries * MaxAutoRetiresNextServer)
      = 2 + 0 + (2 * 0)
      = 2

在加上我們手動請求一次那就是:2 + 1=3次

公式很重要!

感謝各位的閱讀,以上就是“如何解決springcloud中Feign超時的問題”的內容了,經過本文的學習后,相信大家對如何解決springcloud中Feign超時的問題這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

亚洲午夜精品一区二区_中文无码日韩欧免_久久香蕉精品视频_欧美主播一区二区三区美女