深入理解 Golang HTTP Timeout

深入理解 Golang HTTP Timeout

背景

前段時間脓斩,線上服務(wù)器因?yàn)椴糠治⒎?wù)提供的 HTTP API 響應(yīng)慢肺素,而我們沒有用正確的姿勢來處理 HTTP 超時(當(dāng)然,還有少量 RPC 超時), 同時我們也沒有服務(wù)降級策略和容災(zāi)機(jī)制,導(dǎo)致服務(wù)相繼掛掉??。服務(wù)降級和容災(zāi)需要一段時間的架構(gòu)改造,但是以正確的姿勢使用 HTTP 超時確是馬上可以習(xí)得的典挑。

超時的本質(zhì)

所有的 Timeout 都構(gòu)建于 Golang 提供的 Set[Read|Write]Deadline 原語之上。

服務(wù)器超時

server timeout
  • ReadTimout 包括了TCP 消耗的時間啦吧,可以一定程度預(yù)防慢客戶端和意外斷開的客戶端占用文件描述符

  • 對于 https請求您觉,ReadTimeout 包括了 TLS 握手的時間;WriteTimeout 包括了 TLS握手授滓、讀取 Header 的時間(虛線部分), 而 http 請求只包括讀取 body 和寫 response 的時間琳水。

此外,http.ListenAndServe, http.ListenAndServeTLS and http.Serve 等方法都沒有設(shè)置超時般堆,且無法設(shè)置超時在孝。因此不適合直接用來提供公網(wǎng)服務(wù)。正確的姿勢是:


package main

import (

"net/http"

"time"

)

func main() {

server := &http.Server{

Addr:        ":8081",

ReadTimeout:  3 * time.Second,

WriteTimeout: 5 * time.Second,

}

http.HandleFunc("/hi", func(w http.ResponseWriter, r *http.Request) {

w.Write([]byte("hi"))

})

server.ListenAndServe()

}

客戶端超時

client timeout
  • http.Client 會自動跟隨重定向(301, 302), 重定向時間也會記入 http.Client.Timeout, 這點(diǎn)一定要注意淮摔。

取消一個 http request 有兩種方式:

  1. Request.Cancel

  2. Context (Golang >= 1.7.0)

后一種因?yàn)榭梢詡鬟f parent context, 因此可以做級聯(lián) cancel, 效果更佳私沮。代碼示例:


ctx, cancel := context.WithCancel(context.TODO())  // or parant context

timer := time.AfterFunc(5*time.Second, func() { 

    cancel()

})

req, err := http.NewRequest("GET", "http://httpbin.org/range/2048?duration=8&chunk_size=256", nil) 

if err != nil { 

    log.Fatal(err)

}

req = req.WithContext(ctx) 

Credits

  1. The complete guide to Go net/http timeouts

  2. Go middleware for net.Conn tracking (Prometheus/trace)

同步自我的博客深入理解 Golang HTTP Timeout

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市和橙,隨后出現(xiàn)的幾起案子仔燕,更是在濱河造成了極大的恐慌造垛,老刑警劉巖,帶你破解...
    沈念sama閱讀 211,123評論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件晰搀,死亡現(xiàn)場離奇詭異五辽,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)外恕,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,031評論 2 384
  • 文/潘曉璐 我一進(jìn)店門杆逗,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人吁讨,你說我怎么就攤上這事髓迎。” “怎么了建丧?”我有些...
    開封第一講書人閱讀 156,723評論 0 345
  • 文/不壞的土叔 我叫張陵排龄,是天一觀的道長。 經(jīng)常有香客問我翎朱,道長橄维,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,357評論 1 283
  • 正文 為了忘掉前任拴曲,我火速辦了婚禮争舞,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘澈灼。我一直安慰自己竞川,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,412評論 5 384
  • 文/花漫 我一把揭開白布叁熔。 她就那樣靜靜地躺著委乌,像睡著了一般。 火紅的嫁衣襯著肌膚如雪荣回。 梳的紋絲不亂的頭發(fā)上遭贸,一...
    開封第一講書人閱讀 49,760評論 1 289
  • 那天,我揣著相機(jī)與錄音心软,去河邊找鬼壕吹。 笑死,一個胖子當(dāng)著我的面吹牛删铃,可吹牛的內(nèi)容都是我干的耳贬。 我是一名探鬼主播,決...
    沈念sama閱讀 38,904評論 3 405
  • 文/蒼蘭香墨 我猛地睜開眼泳姐,長吁一口氣:“原來是場噩夢啊……” “哼效拭!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,672評論 0 266
  • 序言:老撾萬榮一對情侶失蹤缎患,失蹤者是張志新(化名)和其女友劉穎慕的,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體挤渔,經(jīng)...
    沈念sama閱讀 44,118評論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡肮街,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,456評論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了判导。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片嫉父。...
    茶點(diǎn)故事閱讀 38,599評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖眼刃,靈堂內(nèi)的尸體忽然破棺而出绕辖,到底是詐尸還是另有隱情,我是刑警寧澤擂红,帶...
    沈念sama閱讀 34,264評論 4 328
  • 正文 年R本政府宣布仪际,位于F島的核電站,受9級特大地震影響昵骤,放射性物質(zhì)發(fā)生泄漏树碱。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,857評論 3 312
  • 文/蒙蒙 一变秦、第九天 我趴在偏房一處隱蔽的房頂上張望成榜。 院中可真熱鬧,春花似錦蹦玫、人聲如沸赎婚。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,731評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽惑淳。三九已至,卻和暖如春饺窿,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背移斩。 一陣腳步聲響...
    開封第一講書人閱讀 31,956評論 1 264
  • 我被黑心中介騙來泰國打工肚医, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人向瓷。 一個月前我還...
    沈念sama閱讀 46,286評論 2 360
  • 正文 我出身青樓肠套,卻偏偏與公主長得像,于是被迫代替她去往敵國和親猖任。 傳聞我的和親對象是個殘疾皇子你稚,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,465評論 2 348

推薦閱讀更多精彩內(nèi)容