.NET Core HttpClient請求異常思考
本文轉(zhuǎn)載自微信公眾號「JeffckyShare」,作者Jeffcky 。轉(zhuǎn)載本文請聯(lián)系JeffckyShare公眾號。
下面我們結(jié)合如下兩個異常信息進行大致排查分析,到底什么時候會拋出這兩個異常信息呢?
異常信息分析
上述異常說到底還是連接問題導致,但是連接超時有很多種情況,比如客戶端主動關閉連接,又比如服務端對請求應答超時等等,這里給出僅我個人理解的常見情況,大家可以作為基本參考
大前提:根據(jù)項目實際情況,分析實際業(yè)務對應場景,主要考慮以下最后兩個因素
一是,適當觀察下數(shù)據(jù)量大小,萬一偶爾出現(xiàn)數(shù)據(jù)量達到M級別呢,當然既然考慮HTTP,這種情況可以基本忽略
二是,HTTP是否還能承載對應業(yè)務,排除性能瓶頸
三是,評估考慮是否增加自身平臺請求超時時間設置?同時也清楚自身平臺是否存在請求非常頻繁?以及也一定要了解對接方是否存在處理請求非常耗時?
首先,若以上兩者都不是,可以從網(wǎng)絡原因開始分析,比如防火墻設置(根據(jù)操作系統(tǒng)不同而采取對應方案)、DNS解析設置(有參數(shù)可配置刷新DNS解析)、IP設置、代理設置(有參數(shù)可配置忽略代理)等等
其次,保證啟用客戶端持久化連接以及增加連接數(shù)限制
- //增加?;顧C制,表明連接為長連接
- client.DefaultRequestHeaders.Connection.Add("keep-alive");
- //啟用保活機制(保持活動超時設置為 2 小時,并將保持活動間隔設置為 1 秒。)
- ServicePointManager.SetTcpKeepAlive(true, 7200000, 1000);
- //默認連接數(shù)限制為2,增加連接數(shù)限制
- ServicePointManager.DefaultConnectionLimit = 512;
然后,依然不能解決問題,嘗試使用Socket通信連接
- var client = new HttpClient(new SocketsHttpHandler()
- {
- //考慮忽略使用代理
- UseProxy = false,
- //考慮增加連接數(shù)配置
- MaxConnectionsPerServer = 100,
- //考慮忽略重定向響應
- AllowAutoRedirect = false,
- //考慮忽略SSL證書驗證
- SslOptions = new SslClientAuthenticationOptions()
- {
- RemoteCertificateValidationCallback = (sender, certificate, chain, sslPolicyErrors) => true
- },
- //考慮數(shù)據(jù)壓縮設置
- AutomaticDecompression = DecompressionMethods.Deflate | DecompressionMethods.GZip,
- })
- {
- BaseAddress = new Uri(""),
- Timeout = TimeSpan.FromSeconds(30),
- };
最后,還不能解決問題,若是Windows通過WireShark抓包分析,若是Linux使用tcpdump抓包,結(jié)合WireShark分析
如果其他干擾因素都已經(jīng)基本排除,同時通過WireShark抓包一切正常,是不是沒轍了
自信一點,適當懷疑一下HttpClient本身可能就存在這樣的問題呢?
考慮在Windows和Linux系統(tǒng)分別測試驗證,最終確認是否是HttpClient底層在兩者系統(tǒng)上機制的有些不同,導致存在的bug呢?