掃二維碼與項目經理溝通
我們在微信上24小時期待你的聲音
解答本文疑問/技術咨詢/運營咨詢/技術建議/互聯(lián)網交流
不知道你有沒有過這樣的經歷,你的Spring項目通過http接口遠程調用外部系統(tǒng)時,通常你會設置超時時間,比如5秒鐘,但是實際情況卻是由于外部系統(tǒng)出現(xiàn)故障并導致連接超時,有些請求花費遠遠超過5秒時間,甚至1分鐘,這直接導致你本身的接口響應很慢,如果訪問你接口的流量很大的話,甚至拖垮你的系統(tǒng),這將會是災難性的后果。

成都創(chuàng)新互聯(lián)專注于普蘭企業(yè)網站建設,響應式網站設計,商城網站制作。普蘭網站建設公司,為普蘭等地區(qū)提供建站服務。全流程按需網站制作,專業(yè)設計,全程項目跟蹤,成都創(chuàng)新互聯(lián)專業(yè)和態(tài)度為您提供的服務
你可能會好奇到底是什么原因導致的,很可能是你忽略了這個超時配置項connectionRequestTimeout導致的。
在深入了解 connectionRequestTimeout 之前,我們需要了解外部 HTTP 請求是如何在 Spring 中進行的。
Spring 通過Http調用外部系統(tǒng)的時候,會使用連接池去管理他們。因為HTTP請求創(chuàng)建連接代價比較高,而連接池可以做到連接的復用,回過頭,我們思考下為什么會代價高呢?
為 HTTP 請求使用連接池可以顯著提高性能。但是,我們需要對其進行適當配置以防止出現(xiàn)災難情況。
現(xiàn)在讓我們用連接池的概念再來看問題。
本例中B組件是外部系統(tǒng),處于無法建立HTTP連接的情況,導致A中的連接超時,請仔細看上面A指向連接池的箭頭,A 正在等待另一個連接來建立到 B 的 HTTP 連接。
connectionRequestTimeout 是 Spring 中的一個配置參數,用于確定客戶端在超時前等待來自連接池的連接的時間。此超時值用于防止客戶端無限期地等待可能不可用的連接,并在不再需要時釋放連接池中的資源。
API 響應時間 = connectionRequestTimeout? + connectionTimeout? + readTimeout 。
connectionRequestTimeout 的默認值為 -1,這意味著它無限期地等待來自連接池的連接。由于我們希望避免外部組件中斷導致系統(tǒng)故障,因此我們需要為其設置一個顯式值。
假設您將值設置得太短:1 秒。如果系統(tǒng)需要高延遲,這可能是一個頻繁的故障,因為它可能一直渴望連接。另一方面,如果該值太長,比如 10 分鐘,系統(tǒng)很容易因外部故障而失敗。
因此,你需要統(tǒng)計系統(tǒng)的API響應時間, 最大超時響應時間如下:
API 響應時間 = connectionRequestTimeout + connectionTimeout + readTimeout。
看看是否有很多請求超過了connectionTimeout和readTimeout?之和, 如果是這樣的話,系統(tǒng)需要增大連接池的大小或者減小connectionRequestTimeout?值。否則就將 connectionRequestTimeout 合理設置為 15 秒到 30 秒之間。
下面是設置 connectionRequestTimeout 的示例代碼。
import org.springframework.http.client.HttpComponentsClientHttpRequestFactory;
import org.springframework.web.client.RestTemplate;
public class ConnectionRequestTimeoutExample {
public static void main(String[] args) {
RestTemplate restTemplate = new RestTemplate();
HttpComponentsClientHttpRequestFactory requestFactory = new HttpComponentsClientHttpRequestFactory();
// Set the connectionRequestTimeout value to 10 seconds
requestFactory.setConnectionRequestTimeout(10000);
restTemplate.setRequestFactory(requestFactory);
...
}
}
在這個例子中,我們創(chuàng)建了一個新的RestTemplate?和一個新的HttpComponentsClientHttpRequestFactory?,然后我們connectionRequestTimeout?使用該方法將該值設置為 10 秒,并使用該方法為 RestTemplate? 設置請求工廠setRequestFactory()。
最后,我們在總結以下Spring中Http請求的3個關鍵的超時配置吧,其中connectionRequestTimeout 最容易被忽視的。

我們在微信上24小時期待你的聲音
解答本文疑問/技術咨詢/運營咨詢/技術建議/互聯(lián)網交流