.NET Core HttpClient请求异常思考
【導讀】上一篇我們討論了針對項目上異常信息的具體分析而給出對應解決方案,本篇僅是我個人對相關異常信息了解過后的進一步學習和思考,希望對后續遇到此異常信息的同學們給予思路擴展
下面我們結合如下兩個異常信息進行大致排查分析,到底什么時候會拋出這兩個異常信息呢?
異常信息分析
上述異常說到底還是連接問題導致,但是連接超時有很多種情況,比如客戶端主動關閉連接,又比如服務端對請求應答超時等等,這里給出僅我個人理解的常見情況,大家可以作為基本參考
大前提:根據項目實際情況,分析實際業務對應場景,主要考慮以下最后兩個因素
一是,適當觀察下數據量大小,萬一偶爾出現數據量達到M級別呢,當然既然考慮HTTP,這種情況可以基本忽略
二是,HTTP是否還能承載對應業務,排除性能瓶頸
三是,評估考慮是否增加自身平臺請求超時時間設置?同時也清楚自身平臺是否存在請求非常頻繁?以及也一定要了解對接方是否存在處理請求非常耗時?
首先,若以上兩者都不是,可以從網絡原因開始分析,比如防火墻設置(根據操作系統不同而采取對應方案)、DNS解析設置(有參數可配置刷新DNS解析)、IP設置、代理設置(有參數可配置忽略代理)等等
其次,保證啟用客戶端持久化連接以及增加連接數限制
//增加?;顧C制,表明連接為長連接client.DefaultRequestHeaders.Connection.Add("keep-alive");//啟用保活機制(保持活動超時設置為 2 小時,并將保持活動間隔設置為 1 秒。)ServicePointManager.SetTcpKeepAlive(true,?7200000,?1000);//默認連接數限制為2,增加連接數限制ServicePointManager.DefaultConnectionLimit?=?512;然后,依然不能解決問題,嘗試使用Socket通信連接
最后,還不能解決問題,若是Windows通過WireShark抓包分析,若是Linux使用tcpdump抓包,結合WireShark分析
如果其他干擾因素都已經基本排除,同時通過WireShark抓包一切正常,是不是沒轍了
自信一點,適當懷疑一下HttpClient本身可能就存在這樣的問題呢?
考慮在Windows和Linux系統分別測試驗證,最終確認是否是HttpClient底層在兩者系統上機制的有些不同,導致存在的bug呢?
總結
以上是生活随笔為你收集整理的.NET Core HttpClient请求异常思考的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Blazor 基础入门
- 下一篇: WPF 路径动画PathAnimatio