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