成人性生交大片免费看视频r_亚洲综合极品香蕉久久网_在线视频免费观看一区_亚洲精品亚洲人成人网在线播放_国产精品毛片av_久久久久国产精品www_亚洲国产一区二区三区在线播_日韩一区二区三区四区区区_亚洲精品国产无套在线观_国产免费www

主頁 > 知識庫 > go語言中http超時引發(fā)的事故解決

go語言中http超時引發(fā)的事故解決

熱門標(biāo)簽:百度地圖標(biāo)注位置網(wǎng)站 如何利用高德地圖標(biāo)注家 武漢百應(yīng)人工智能電銷機(jī)器人 開通400電話申請流程 智能語音電銷的機(jī)器人 400手機(jī)電話免費(fèi)辦理 揚(yáng)州電銷外呼系統(tǒng)軟件 上海企業(yè)外呼系統(tǒng)排名 電腦外呼系統(tǒng)輻射大嗎

前言

我們使用的是golang標(biāo)準(zhǔn)庫的http client,對于一些http請求,我們在處理的時候,會考慮加上超時時間,防止http請求一直在請求,導(dǎo)致業(yè)務(wù)長時間阻塞等待。

最近同事寫了一個超時的組件,這幾天訪問量上來了,網(wǎng)絡(luò)也出現(xiàn)了波動,造成了接口在報錯超時的情況下,還是出現(xiàn)了請求結(jié)果的成功。

分析下具體的代碼實(shí)現(xiàn)

type request struct {
 method string
 url    string
 value  string
 ps     *params
}

type params struct {
 timeout     int //超時時間
 retry       int //重試次數(shù)
 headers     map[string]string
 contentType string
}

func (req *request) Do(result interface{}) ([]byte, error) {
 res, err := asyncCall(doRequest, req)
 if err != nil {
  return nil, err
 }

 if result == nil {
  return res, nil
 }

 switch req.ps.contentType {
 case "application/xml":
  if err := xml.Unmarshal(res, result); err != nil {
   return nil, err
  }
 default:
  if err := json.Unmarshal(res, result); err != nil {
   return nil, err
  }
 }

 return res, nil
}
type timeout struct {
 data []byte
 err  error
}


func doRequest(request *request) ([]byte, error) {
 var (
  req    *http.Request
  errReq error
 )
 if request.value != "null" {
  buf := strings.NewReader(request.value)
  req, errReq = http.NewRequest(request.method, request.url, buf)
  if errReq != nil {
   return nil, errReq
  }
 } else {
  req, errReq = http.NewRequest(request.method, request.url, nil)
  if errReq != nil {
   return nil, errReq
  }
 }
 // 這里的client沒有設(shè)置超時時間
 // 所以當(dāng)下面檢測到一次超時的時候,會重新又發(fā)起一次請求
 // 但是老的請求其實(shí)沒有被關(guān)閉,一直在執(zhí)行
 client := http.Client{}
 res, err := client.Do(req)
 ...
}

// 重試調(diào)用請求
// 當(dāng)超時的時候發(fā)起一次新的請求
func asyncCall(f func(request *request) ([]byte, error), req *request) ([]byte, error) {
 p := req.ps
 ctx := context.Background()
 done := make(chan *timeout, 1)

 for i := 0; i  p.retry; i++ {
  go func(ctx context.Context) {
   // 發(fā)送HTTP請求
   res, err := f(req)
   done - timeout{
    data: res,
    err:  err,
   }
  }(ctx)
  // 錯誤主要在這里
  // 如果超時重試為3,第一次超時了,馬上又發(fā)起了一次新的請求,但是這里錯誤使用了超時的退出
  // 具體看上面
  select {
  case res := -done:
   return res.data, res.err
  case -time.After(time.Duration(p.timeout) * time.Millisecond):
  }
 }
 return nil, ecode.TimeoutErr
}

錯誤的原因

1、超時重試,之后過了一段時間沒有拿到結(jié)果就認(rèn)為是超時了,但是http請求沒有被關(guān)閉;

2、錯誤使用了http的超時,具體的做法要通過context或http.client去實(shí)現(xiàn),見下文;

修改之后的代碼

func doRequest(request *request) ([]byte, error) {
 var (
  req    *http.Request
  errReq error
 )
 if request.value != "null" {
  buf := strings.NewReader(request.value)
  req, errReq = http.NewRequest(request.method, request.url, buf)
  if errReq != nil {
   return nil, errReq
  }
 } else {
  req, errReq = http.NewRequest(request.method, request.url, nil)
  if errReq != nil {
   return nil, errReq
  }
 }

 // 這里通過http.Client設(shè)置超時時間
 client := http.Client{
  Timeout: time.Duration(request.ps.timeout) * time.Millisecond,
 }
 res, err := client.Do(req)
 ...
}

func asyncCall(f func(request *request) ([]byte, error), req *request) ([]byte, error) {
 p := req.ps
 // 重試的時候只有上一個http請求真的超時了,之后才會發(fā)起一次新的請求
 for i := 0; i  p.retry; i++ {
  // 發(fā)送HTTP請求
  res, err := f(req)
  // 判斷超時
  if netErr, ok := err.(net.Error); ok  netErr.Timeout() {
   continue
  }

  return res, err

 }
 return nil, ecode.TimeoutErr
}

服務(wù)設(shè)置超時

http.Server有兩個設(shè)置超時的方法:

ReadTimeout
ReadTimeout的時間計(jì)算是從連接被接受(accept)到request body完全被讀取(如果你不讀取body,那么時間截止到讀完header為止)

WriteTimeout
WriteTimeout的時間計(jì)算正常是從request header的讀取結(jié)束開始,到response write結(jié)束為止 (也就是ServeHTTP方法的生命周期)

srv := http.Server{  
    ReadTimeout: 5 * time.Second,
    WriteTimeout: 10 * time.Second,
}

 
srv.ListenAndServe()

net/http包還提供了TimeoutHandler返回了一個在給定的時間限制內(nèi)運(yùn)行的handler

func TimeoutHandler(h Handler, dt time.Duration, msg string) Handler

第一個參數(shù)是Handler,第二個參數(shù)是time.Duration(超時時間),第三個參數(shù)是string類型,當(dāng)?shù)竭_(dá)超時時間后返回的信息

func handler(w http.ResponseWriter, r *http.Request) {
 time.Sleep(3 * time.Second)
 fmt.Println("測試超時")

 w.Write([]byte("hello world"))
}

func server() {
 srv := http.Server{
  Addr:         ":8081",
  WriteTimeout: 1 * time.Second,
  Handler:      http.TimeoutHandler(http.HandlerFunc(handler), 5*time.Second, "Timeout!\n"),
 }
 if err := srv.ListenAndServe(); err != nil {
  os.Exit(1)
 }
}

客戶端設(shè)置超時

http.client
最簡單的我們通過http.Client的Timeout字段,就可以實(shí)現(xiàn)客戶端的超時控制

http.client超時是超時的高層實(shí)現(xiàn),包含了從Dial到Response Body的整個請求流程。http.client的實(shí)現(xiàn)提供了一個結(jié)構(gòu)體類型可以接受一個額外的time.Duration類型的Timeout屬性。這個參數(shù)定義了從請求開始到響應(yīng)消息體被完全接收的時間限制。

func httpClientTimeout() {
 c := http.Client{
  Timeout: 3 * time.Second,
 }

 resp, err := c.Get("http://127.0.0.1:8081/test")
 fmt.Println(resp)
 fmt.Println(err)
}

context
net/http中的request實(shí)現(xiàn)了context,所以我們可以借助于context本身的超時機(jī)制,實(shí)現(xiàn)http中request的超時處理

func contextTimeout() {
 ctx, cancel := context.WithTimeout(context.Background(), 3*time.Second)
 defer cancel()

 req, err := http.NewRequest("GET", "http://127.0.0.1:8081/test", nil)
 if err != nil {
  log.Fatal(err)
 }

 resp, err := http.DefaultClient.Do(req.WithContext(ctx))
 fmt.Println(resp)
 fmt.Println(err)
}

使用context的優(yōu)點(diǎn)就是,當(dāng)父context被取消時,子context就會層層退出。

http.Transport
通過Transport還可以進(jìn)行一些更小維度的超時設(shè)置

  • net.Dialer.Timeout 限制建立TCP連接的時間
  • http.Transport.TLSHandshakeTimeout 限制 TLS握手的時間
  • http.Transport.ResponseHeaderTimeout 限制讀取response header的時間
  • http.Transport.ExpectContinueTimeout 限制client在發(fā)送包含 Expect: 100-continue的header到收到繼續(xù)發(fā)送body的response之間的時間等待。注意在1.6中設(shè)置這個值會禁用HTTP/2(DefaultTransport自1.6.2起是個特例)
func transportTimeout() {
 transport := http.Transport{
  DialContext:           (net.Dialer{}).DialContext,
  ResponseHeaderTimeout: 3 * time.Second,
 }

 c := http.Client{Transport: transport}

 resp, err := c.Get("http://127.0.0.1:8081/test")
 fmt.Println(resp)
 fmt.Println(err)
}

問題
如果在客戶端在超時的臨界點(diǎn),觸發(fā)了超時機(jī)制,這時候服務(wù)端剛好也接收到了,http的請求

這種服務(wù)端還是可以拿到請求的數(shù)據(jù),所以對于超時時間的設(shè)置我們需要根據(jù)實(shí)際情況進(jìn)行權(quán)衡,同時我們要考慮接口的冪等性。

總結(jié)

1、所有的超時實(shí)現(xiàn)都是基于Deadline,Deadline是一個時間的絕對值,一旦設(shè)置他們永久生效,不管此時連接是否被使用和怎么用,所以需要每手動設(shè)置,所以如果想使用SetDeadline建立超時機(jī)制,需要每次在Read/Write操作之前調(diào)用它。

2、使用context進(jìn)行超時控制的好處就是,當(dāng)父context超時的時候,子context就會層層退出。

參考

【[譯]Go net/http 超時機(jī)制完全手冊】
【Go 語言 HTTP 請求超時入門】
【使用 timeout、deadline 和 context 取消參數(shù)使 Go net/http 服務(wù)更靈活】

到此這篇關(guān)于go語言中http超時引發(fā)的事故解決的文章就介紹到這了,更多相關(guān)go語言 http超時內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • 解決Goland中利用HTTPClient發(fā)送請求超時返回EOF錯誤DEBUG
  • Go中http超時問題的排查及解決方法
  • golang http 連接超時和傳輸超時的例子

標(biāo)簽:黑龍江 新余 延邊 宜賓 江西 武漢 嘉峪關(guān) 張掖

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《go語言中http超時引發(fā)的事故解決》,本文關(guān)鍵詞  語,言中,http,超時,引發(fā),;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《go語言中http超時引發(fā)的事故解決》相關(guān)的同類信息!
  • 本頁收集關(guān)于go語言中http超時引發(fā)的事故解決的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    xxxxxx在线观看| 吞精囗交69激情欧美| 亚洲精品理论电影| 日韩在线你懂的| 妖精视频一区二区三区免费观看| 亚洲精品乱码电影在线观看| 男人的天堂亚洲| 亚洲跨种族黑人xxx| 无码人妻av一区二区三区波多野| 性网站在线免费观看| 亚洲综合123| 精品少妇一区二区三区日产乱码| 国产精品久久久久久久久久久久久久久久久| 女人扒开双腿让男人捅| 国产色综合一区| 亚洲精品一区二区在线| 黄色成人免费看| 台湾佬美性中文| 天天插天天干天天操| 丁香亚洲综合激情啪啪综合| 国产精品不卡在线观看| 国产一区二区三区欧美| 国模大尺度视频一区二区| 国产成人免费视频| 亚洲国产午夜伦理片大全在线观看网站| 亚洲国产精华液网站w| 欧美日韩国产首页在线观看| 毛片电影在线| 亚洲成年人在线| 51视频国产精品一区二区| 欧美精品一区二区成人| 在线免费黄色av| 精品无码一区二区三区的天堂| 精品视频在线播放一区二区三区| 久久久国产精品成人免费| 国产精成人品2018| 精品久久久网| 精品国产免费一区二区三区四区| 快播亚洲色图| 午夜精品av| 成人国产视频在线观看| 2020国产精品视频| 亚洲电影中文字幕在线观看| 爱看av在线入口| 欧美日韩精品二区| 亚洲瘦老头同性70tv| 国产成人精品a视频一区www| 久久久久99精品成人| 日韩视频在线观看视频| 久草中文在线视频| 九色视频入口| 国内精品美女在线观看| 成人欧美一区二区三区| 久久久国产成人精品| 电影在线观看一区| 在线观看91| 日本sm极度另类视频| 久久精品国产一区| 亚洲自拍偷拍图区| 欧洲精品99毛片免费高清观看| 欧美日韩一二区| av污在线观看| 亚洲一区国产一区| 欧美性aaa| 日本少妇吞精囗交| 丰满人妻中伦妇伦精品app| 欧美xxxxx性| 九九九九热精品免费视频| 日韩国产专区| www亚洲精品| 精品福利在线看| 综合久久伊人| 久久精品91久久香蕉加勒比| 欧美男女视频| 国产精品精品国产一区二区| 十九岁完整版在线观看好看云免费| 北条麻妃一区二区三区在线观看| 黄色av中文字幕| 伊人久久在线| 成年人视频软件| 亚洲欧美一区二区激情| 欧美精品成人在线| 亚洲第一色av| 黑人巨大40厘米重口ysn| 97人人爽人人喊人人模波多| 久久精品国产露脸对白| 91久久久久久白丝白浆欲热蜜臀| 亚洲免费观看高清在线观看| 中文字幕综合网| 午夜在线电影亚洲一区| 婷婷伊人五月天| 夜鲁很鲁在线视频| 亚洲v精品v日韩v欧美v专区| 手机在线免费看片| 国产精品久久国产三级国电话系列| 亚洲av无码国产精品麻豆天美| 神马久久午夜| 精品制服美女丁香| 欧美wwwwxxxx| 欧美精品国产精品久久久| 欧美视频第一页| 精品一区二区三区av| 校花撩起jk露出白色内裤国产精品| 国产肉体xxxx裸体784大胆| 91精品国产一区二区三密臀| 操日韩av在线电影| y111111国产精品久久婷婷| 久久久精品一区二区涩爱| 人妻丰满熟妇aⅴ无码| 久热在线视频观看| 亚洲天堂网站在线观看视频| 中文字幕无码乱码人妻日韩精品| 91激情视频在线观看| 亚洲精品伦理在线| 日韩三区视频| 国产黄在线看| 国产精品99久久免费| 亚洲成色777777女色窝| 欧美日韩一区精品| 无码人妻丰满熟妇区五十路| 天天综合久久综合| 久久国产精品99久久人人澡| 好吊日精品视频| 国产精品99久久久久| 国产精品区在线观看| 国产av自拍一区| 午夜精品一区二区在线观看的| 激情综合五月网| 一区中文字幕| 国产一区二区三区免费| 永久av免费在线观看| 亚洲少妇中出一区| 日韩在线视频免费观看高清中文| 日本系列第一页| 国产精品久久久久久婷婷天堂| 亚洲综合极品香蕉久久网| 国产噜噜噜噜噜久久久久久久久| 欧美性色黄大片手机版| 久久免费高清视频| 一区二区三区 在线观看视| 国产一级生活片| 91国语精品自产拍| 久久精品成人一区二区三区蜜臀| 97人洗澡人人免费公开视频碰碰碰| 欧美天堂影院| 91视频免费进入| 99久久国产综合色|国产精品| 开心激情五月婷婷| 国产一区高清| 日本中文字幕在线播放| 欧美一区二区三区在线播放| 99在线免费观看视频| 欧美性精品220| 国产成人免费精品| 亚洲www啪成人一区二区麻豆| 国产日本欧美一区二区三区| 国产精品久久久久久久免费软件| 国产精品久久久免费看| 亚洲视频一二区| 亚洲精品永久视频| 亚洲精品欧美极品| 美女被男人操网站| 成人av资源在线观看| 给我免费播放片在线观看| 精品无人区乱码1区2区3区在线| 日韩欧美三级在线观看| 99这里只有久久精品视频| 国产在成人精品线拍偷自揄拍| 亚洲熟女一区二区| 欧美亚洲愉拍一区二区| 久久精品国产亚洲7777| 久久蜜臀中文字幕| 思思99re6国产在线播放| 久久精品亚洲精品国产欧美| 女王人厕视频2ⅴk| 国产精一品亚洲二区在线视频| 国产精品不卡在线观看| 成人性生交大片免费看中文| 欧美中文字幕精品| 91久久夜色精品国产按摩| 中文字幕一区二区三区不卡在线| 日本中文字幕电影| 高清av免费一区中文字幕| 欧美扣逼视频| 久久久伦理片| 免费在线观看污污视频| 亚洲日本网址| 午夜精品视频在线| 99三级在线| 97精品国产97久久久久久免费| 欧美精品免费视频| 欧美激情视频一区二区三区| 日本电影在线观看| 欧美xxxx×黑人性爽| 超碰色偷偷男人的天堂| 国产精品1区在线| 爱啪导航一精品导航站| 成人一级福利| 久久天天久久| 宅男噜噜噜66一区二区66| 欧美性精品220| 精品国产999久久久免费| 538在线观看| 久久久成人免费视频| 久久最新视频| 国产一级精品在线| 日韩成人在线电影| 久久久久久欧美精品色一二三四| 精品国精品国产自在久不卡| 中文字幕亚洲日本岛国片| 欧美另类暴力丝袜| 中文字幕免费在线观看| 欧美大片在线观看| 久久久久久久综合狠狠综合| 免费的av网址| 在线播放av中文字幕| 久久精品国产理论片免费| 国产福利精品一区二区| 亚洲精品无码专区| 色狠狠一区二区| 国产精品999久久久| 午夜av噜噜噜噜噜噜| 澳门黄色一级片| 免费一级a毛片夜夜看| 久久久97精品| 天堂网在线观看在线观看精品| 久久网免费视频| 色综合久久五月天| 麻豆91在线播放| 软萌小仙自慰喷白浆| 在线观看免费不卡av| 精品视频在线免费观看| 成人黄动漫网站免费| 在线观看理论片| 日韩精品一区二区三区色偷偷| 亚洲精品久久| 欧美婷婷久久五月精品三区| 欧美精品久久久久久久多人混战| 欧美成人sm免费视频| 国产一区高清视频| 国内免费精品视频| 欧美va久久久噜噜噜久久| yellow中文字幕久久| 免费人成黄页在线观看忧物| 成人免费视频在线观看超级碰| 在线免费观看www| 欧美在线导航| 天堂资源最新版在线视频观看免费网| 国产日韩欧美精品一区二区三区| 欧美日韩一区二区区别是什么| 天天撸夜夜操| jizz中文字幕| 日韩视频在线一区二区三区| 欧美日韩成人在线| 午夜精品久久一牛影视| 91在线资源| 无遮挡aaaaa大片免费看| 欧美成ee人免费视频| 午夜福利一区二区三区| 欧洲激情视频| 69视频在线播放| 99精品国产在热久久下载| 五月婷婷综合激情网| 午夜精品一区二区三区在线视频| 日韩女优视频免费观看| 91精品国自产在线观看| 污污软件在线观看| 欧美激情欧美激情| 天天综合网网欲色| 欧美刺激性大交免费视频| 黄色成人在线观看网站| 26uuu久久天堂性欧美| 亚洲成人中文字幕在线| 亚洲精品系列| 国产一区二区三区四区五区加勒比| 欧美一级淫片免费视频魅影视频| 一级片avav网址| 亚洲麻豆av| 亚洲人成精品久久久久久| 伊人精品在线视频| 开心久久婷婷综合中文字幕| 手机在线看片日韩| jizzjizz在线| 免费中文字幕在线观看| 久久精品国产99精品国产亚洲性色| 欧美日韩在线视频一区二区三区| 天天干天天插天天射| 中文字幕亚洲自拍| 一区二区三区国产视频| 奇米色一区二区| 中文字幕日韩av| 蜜桃免费网站一区二区三区| 欧美黑人巨大videos精品| 在线观看网站免费入口在线观看国内| 国产一区二区三区精品在线| 久久影院理伦片| 无遮挡的视频在线观看| 中文字幕欧美日韩va免费视频| 欧美成人精品二区三区99精品| 午夜国产欧美理论在线播放| 亚洲午夜精品久久久久久浪潮| 亚洲女人天堂色在线7777| 亚洲国产精品久久久久久女王| 一区二区三区毛片免费| a天堂中文在线官网在线| 久久久亚洲欧洲日产国码aⅴ| 在线免费看黄色| 色94色欧美sute亚洲线路一久| 日韩三区在线观看| √天堂8资源中文在线| 国产视频一区二区三| 韩国精品久久久| 三级ai视频| 午夜激情成人网| 亚洲成人777777| 成年无码av片在线| 久久久久久久久久久久久9999| 国产精品一区一区| 国产精品99一区二区三| 艳妇乳肉豪妇荡乳av| 欧美插天视频在线播放| 欧美一区二区三区综合| 日韩精品资源| 国产精品欧美亚洲| 全网免费在线播放视频入口| 欧美性生给视频| 最近更新在线中文字幕一页| 成人自拍偷拍|