解決Goland中利用HTTPClient發(fā)送請求超時返回EOF錯誤DEBUG
今天解決了一個疑難雜癥,起因是之前代理某內(nèi)部API接口,請求先是出現(xiàn)卡頓,超時后報EOF錯誤。
但奇怪的是線上測試環(huán)境確是沒問題的。
Google了一下,有人說可能是由于重復請求次數(shù)過多導致,應該設(shè)置req.Close屬性為true,這樣不會反復利用一次連接。
嘗試該操作后依然無法解決問題,遂求助同事璟文。
經(jīng)過大牛的一番調(diào)查后,發(fā)現(xiàn)時TCP超時,連接斷了。至于原因,是由于Goland設(shè)置了代理。。。Orz
不過經(jīng)歷這次事件我也學到了利用MAC自帶的活動監(jiān)視器,來查看網(wǎng)絡行為,璟文是看到了接口的轉(zhuǎn)發(fā),才想到了可能是代理的問題。正是由于Goland的代理,才導致了連接內(nèi)部API超時。
補充:golang http 請求未釋放造成的錯誤
昨天在群里有個朋友問了這樣的一個問題
遇到
http:accept error TCP too many open files in 1s
我猜應該是沒有 及時的釋放。他那個 lsof 發(fā)現(xiàn)有好多的 tcp 請求
然后看了一下他的那個代碼
那個請求的關(guān)閉給注釋掉了。
怪不得出現(xiàn)這種情況。
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。如有錯誤或未考慮完全的地方,望不吝賜教。
相關(guān)文章
自己動手用Golang實現(xiàn)約瑟夫環(huán)算法的示例
這篇文章主要介紹了自己動手用Golang實現(xiàn)約瑟夫環(huán)算法的示例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2019-12-12golang解析json數(shù)據(jù)的4種方法總結(jié)
在日常工作中每一名開發(fā)者,不管是前端還是后端,都經(jīng)常使用 JSON,下面這篇文章主要給大家介紹了關(guān)于golang解析json數(shù)據(jù)的4種方法,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下2023-06-06Go中time.RFC3339 時間格式化的實現(xiàn)
這篇文章主要介紹了Go中time.RFC3339 時間格式化的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2021-01-01golang?gorm的預加載及軟刪硬刪的數(shù)據(jù)操作示例
這篇文章主要介紹了golang?gorm的預加載及軟刪硬刪的數(shù)據(jù)操作示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步早日升職加薪2022-04-04Go?Gin框架優(yōu)雅重啟和停止實現(xiàn)方法示例
Web應用程序中,有時需要重啟或停止服務器,無論是因為更新代碼還是進行例行維護,這時需要保證應用程序的可用性和數(shù)據(jù)的一致性,就需要優(yōu)雅地關(guān)閉和重啟應用程序,即不丟失正在處理的請求和不拒絕新的請求,本文將詳解如何在Go語言中使用Gin這個框架實現(xiàn)優(yōu)雅的重啟停止2024-01-01