校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁 > 知識庫 > golang http使用踩過的坑與填坑指南

golang http使用踩過的坑與填坑指南

熱門標簽:阿克蘇地圖標注 評價高的400電話辦理 百度地圖標注后傳給手機 電話機器人軟件免費 外呼系統(tǒng)顯本地手機號 excel地圖標注分布數據 涿州代理外呼系統(tǒng) 外呼系統(tǒng)用什么卡 壽光微信地圖標注

golang對http進行了很好的封裝, 使我們在開發(fā)基于http服務的時候, 十分的方便, 但是良好的封裝, 很容易是的我們忽略掉它們底層的實現細節(jié)。

如下是我踩過的一些坑, 以及相應的解決方法。

調用http服務

通常的實踐如下:

resp, err := http.Get("http://example.com/")
if err != nil {
               // handle error
}
defer resp.Body.Close()
body, err := ioutil.ReadAll(resp.Body)
// ...

陷阱一: Response body沒有及時關閉

網絡程序運行中, 過了一段時間, 比較常見的問題就是爆出錯誤:“socket: too many open files”, 這通常是由于打開的文件句柄沒有關閉造成的。

在http使用中, 最容易讓人忽視的, 就是http返回的response的body必須close,否則就會有內存泄露。

更不容易發(fā)現的問題是, 如果response.body的內容沒有被讀出來, 會造成socket鏈接泄露, 后續(xù)的服務無法使用。

這里, response.body是一個io.ReadCloser類型的接口, 包含了read和close接口。

 type Response struct { 
    // Body represents the response body.
    //
    // The response body is streamed on demand as the Body field
    // is read. If the network connection fails or the server
    // terminates the response, Body.Read calls return an error.
    //
    // The http Client and Transport guarantee that Body is always
    // non-nil, even on responses without a body or responses with
    // a zero-length body. It is the caller's responsibility to
    // close Body. The default HTTP client's Transport may not
    // reuse HTTP/1.x "keep-alive" TCP connections if the Body is
    // not read to completion and closed.
    //
    // The Body is automatically dechunked if the server replied
    // with a "chunked" Transfer-Encoding.
    Body io.ReadCloser
 }

如果沒有通過ioutil.ReadAll或者其他的接口讀取response.body的內容, 此次socket鏈接就無法被后續(xù)的連接復用, 造成的結果就是該連接一直存在。

盡管調用了ioutil.ReadAll就可以避免該連接的泄露, 我們還是建議在獲取response后, 就調用Close, 因為在response返回的地方與ReadAll之間, 萬一有條件判斷造成接口提前返回, 還是會造成泄露的。

defer resp.Body.Close()

另外, http.Request是不需要主動關閉的。

陷阱二: 默認的http的transport的設定不合適

在簡單的應用下, 采用默認的http client就可以滿足需要, 在稍微復雜一點的場景, 有其實想要保持長鏈接以及提高鏈接復用的效率等方面的控制, 這個時候就需要對client比較清楚的了解。

type Client struct {
    // Transport specifies the mechanism by which individual
    // HTTP requests are made.
    // If nil, DefaultTransport is used.
    Transport RoundTripper  
    // Timeout specifies a time limit for requests made by this
    // Client. The timeout includes connection time, any
    // redirects, and reading the response body. The timer remains
    // running after Get, Head, Post, or Do return and will
    // interrupt reading of the Response.Body.
    //
    // A Timeout of zero means no timeout.
    //
    // The Client cancels requests to the underlying Transport
    // as if the Request's Context ended.
    //
    // For compatibility, the Client will also use the deprecated
    // CancelRequest method on Transport if found. New
    // RoundTripper implementations should use the Request's Context
    // for cancelation instead of implementing CancelRequest.
    Timeout time.Duration
}

這里, 我們重點關注Transport與Timeout兩個字段, Transport記錄了本次請求的事務信息, 以及連接復用相關的信息。

Timeout記錄此次調用的超時時間以避免異常發(fā)生的時候的長時間等待。

通常我們使用的默認的Transport定義如下:

var DefaultTransport RoundTripper = Transport{
    Proxy: ProxyFromEnvironment,
    DialContext: (net.Dialer{
        Timeout:   30 * time.Second,
        KeepAlive: 30 * time.Second,
        DualStack: true,
    }).DialContext,
    MaxIdleConns:          100,
    IdleConnTimeout:       90 * time.Second,
    TLSHandshakeTimeout:   10 * time.Second,
    ExpectContinueTimeout: 1 * time.Second,
}

默認情況下, 它會保留打開的連接以備未來復用, 如果服務要連接很多的主機, 就會保存很多的空閑連接, IdleConnTimeout用來將超過一定時間的空閑連接回收;實際上, Defaulttransport 的MaxIdleConns是100, 在很多的場景下還是偏小的, 尤其是對于需要管理大的系統(tǒng)并且模塊之間交互頻繁的情況。

另外, 如果該連接需要定期 訪問很多的資源節(jié)點, 并列我們知道每個資源節(jié)點上面需要的連接數大于2, 那么就會出現很多的短連接, 因為對于每一臺資源機, DefaultTransport默認的最大連接數是2, 最大空閑連接是1.

 type Transport struct {
     // MaxIdleConnsPerHost, if non-zero, controls the maximum idle
    // (keep-alive) connections to keep per-host. If zero,
    // DefaultMaxIdleConnsPerHost is used.
    MaxIdleConnsPerHost int
    
    // MaxConnsPerHost optionally limits the total number of
    // connections per host, including connections in the dialing,
    // active, and idle states. On limit violation, dials will block.
    //
    // Zero means no limit.
    //
    // For HTTP/2, this currently only controls the number of new
    // connections being created at a time, instead of the total
    // number. In practice, hosts using HTTP/2 only have about one
    // idle connection, though.
    MaxConnsPerHost int
}

HTTP的長連接與TCP的長連接

在http1.1中, http默認保持長連接, 以備將來復用, 但是這個長連接通常是有時間限制的, 并且向我們上面開到的Transport里面的設定, 空閑的連接數是有最大限制的, 超過了該限制,其余新的連接就變成了短連接。

TCP協(xié)議本身是長連接, 它超過一定時間沒有數據傳送, 就會發(fā)送心跳來檢測該連接是否存活, 如果是, 該連接繼續(xù)有效。

補充:golang 設置 http response 響應頭的內容與坑

用 golang 寫 http server 時,可以很方便可通過 w.Header.Set(k, v) 來設置 http response 中 header 的內容。

例如:w.Header().Set("Access-Control-Allow-Origin", "*") 。

但是需要特別注意的是某些時候不僅要修改 http header ,還要修改 http status code。

修改 http status code 可以通過:w.WriteHeader(code) 來實現,例如:w.WriteHeader(404) 。

如果這兩種修改一起做,就必須讓 w.WriteHeader 在所有的 w.Header.Set 之后,也就是 w.WriteHeader 后 Set Header 是無效的。

今天就遇到了這個問題,在一段代碼中調用 w.Header.Set,怎么折騰都無效,最后才發(fā)現其它代碼段中先調用了 w.WriteHeader。

以上為個人經驗,希望能給大家一個參考,也希望大家多多支持腳本之家。如有錯誤或未考慮完全的地方,望不吝賜教。

您可能感興趣的文章:
  • go 原生http web 服務跨域restful api的寫法介紹
  • Go http client 連接池不復用的問題
  • Golang實現http server提供壓縮文件下載功能
  • golang語言http協(xié)議get拼接參數操作
  • 在go文件服務器加入http.StripPrefix的用途介紹
  • Golang 實現分片讀取http超大文件流和并發(fā)控制
  • Go 實現HTTP中間人代理的操作

標簽:雞西 汕頭 蘭州 重慶 欽州 銅川 吐魯番 梅河口

巨人網絡通訊聲明:本文標題《golang http使用踩過的坑與填坑指南》,本文關鍵詞  golang,http,使用,踩過,的,;如發(fā)現本文內容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內容系統(tǒng)采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《golang http使用踩過的坑與填坑指南》相關的同類信息!
  • 本頁收集關于golang http使用踩過的坑與填坑指南的相關信息資訊供網民參考!
  • 推薦文章
    校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃
    中文字幕一区在线| 欧美日韩精品电影| 午夜成人在线视频| 国产精品拍天天在线| 欧美色综合影院| 成人av网址在线观看| 精品亚洲porn| 亚洲国产日日夜夜| 亚洲第一福利一区| 亚洲精选视频免费看| 国产无人区一区二区三区| 日韩一区二区在线观看视频播放| 99久久久无码国产精品| 国产米奇在线777精品观看| 亚洲国产wwwccc36天堂| 一区二区激情小说| 艳妇臀荡乳欲伦亚洲一区| 中文av字幕一区| 久久久久国产一区二区三区四区| 欧美日韩国产不卡| 日韩一区二区三区电影| 91精品欧美福利在线观看| 欧美日韩一二三| 日本丶国产丶欧美色综合| 波多野结衣一区二区三区| 色婷婷久久久久swag精品| 色www精品视频在线观看| 91香蕉视频mp4| 91麻豆免费观看| 欧美日韩综合在线| 欧美一级午夜免费电影| 日韩欧美一区中文| 欧美xxxx老人做受| 久久久精品国产免费观看同学| 久久免费美女视频| 亚洲免费av高清| 石原莉奈在线亚洲三区| 国产一区二区三区四区五区入口 | 日韩欧美一区二区久久婷婷| 日韩视频中午一区| 国产精品毛片久久久久久| 亚洲美女屁股眼交| 天堂av在线一区| 成人性生交大合| 欧美日韩国产在线观看| 精品91自产拍在线观看一区| 欧美韩国一区二区| 午夜av电影一区| 99视频精品全部免费在线| 91精品国产乱码| 亚洲人精品一区| 国产精品资源在线看| 欧美美女视频在线观看| 欧美激情中文字幕| 国产在线不卡一区| 欧美日韩国产高清一区二区| 国产精品美女久久久久久久| 久久99精品一区二区三区| 欧洲日韩一区二区三区| 国产精品久久久久一区| 国产一区二区视频在线| 5月丁香婷婷综合| 国产精品成人免费在线| 国内成人免费视频| 精品久久人人做人人爱| 日韩黄色小视频| 欧美色图第一页| 亚洲欧洲韩国日本视频| 国产91丝袜在线观看| 91麻豆精品国产91久久久 | 色94色欧美sute亚洲线路一久| 2024国产精品| 韩国精品在线观看| 国产精品久久久久久久久久久免费看 | 亚洲伦理在线免费看| 国产精品一级二级三级| 国产欧美一区二区在线观看| 国产精品1区2区| 中文字幕巨乱亚洲| 色综合久久久久综合体| 亚洲精品亚洲人成人网在线播放| 91视频在线观看| 亚洲风情在线资源站| 日韩视频免费观看高清完整版在线观看 | 在线播放91灌醉迷j高跟美女 | 亚洲国产成人精品视频| 欧美日韩一区中文字幕| 一区二区不卡在线播放| 欧美精品三级日韩久久| 国产一区999| 一个色综合av| 精品捆绑美女sm三区| 成人av在线看| 青青青伊人色综合久久| 国产精品久久影院| 欧美精品aⅴ在线视频| 国产黄色成人av| 日韩一区精品视频| 国产偷国产偷精品高清尤物| av电影在线观看完整版一区二区| 一区二区三区四区乱视频| 欧美成人猛片aaaaaaa| 在线视频亚洲一区| 国产精品正在播放| 日韩福利视频导航| 国产一区二区在线电影| 亚洲一区二区美女| 成人欧美一区二区三区黑人麻豆| 日韩女优av电影| 在线观看不卡一区| 成人一区二区三区视频| 奇米色777欧美一区二区| 亚洲综合在线第一页| 日韩码欧中文字| 国产精品美女久久久久aⅴ国产馆| 日韩美女主播在线视频一区二区三区| 色综合天天综合在线视频| 国产成人免费xxxxxxxx| 国产精品99久久久久久久vr| 国内精品久久久久影院色| 六月婷婷色综合| 国产综合久久久久久鬼色| 免费的成人av| 九九久久精品视频| 国产suv精品一区二区三区 | 日韩黄色片在线观看| 亚洲一区二区视频| 蜜臀精品一区二区三区在线观看| 日韩激情在线观看| 国产激情精品久久久第一区二区 | 国产精品视频yy9299一区| 国产精品乱子久久久久| 亚洲视频香蕉人妖| 亚洲国产精品一区二区www | 夫妻av一区二区| 日本精品一区二区三区高清| 欧美裸体bbwbbwbbw| 久久久青草青青国产亚洲免观| 久久精品水蜜桃av综合天堂| 国产精品理伦片| 一区二区三区国产精华| 日本女人一区二区三区| 丰满放荡岳乱妇91ww| 欧美亚洲综合在线| 精品粉嫩超白一线天av| 国产人伦精品一区二区| 一区二区免费在线| 国产精一区二区三区| 色综合久久久久久久| 久久综合资源网| 五月天亚洲婷婷| 91老司机福利 在线| 欧美一个色资源| 一区二区国产视频| 丁香一区二区三区| 2023国产精华国产精品| 日产国产欧美视频一区精品| 91麻豆文化传媒在线观看| 久久精品欧美一区二区三区麻豆| 亚洲国产精品久久不卡毛片| 成人国产精品免费网站| 欧美mv和日韩mv的网站| 免费高清成人在线| 欧美日韩www| 香蕉乱码成人久久天堂爱免费| 激情亚洲综合在线| 日韩三级电影网址| 麻豆精品在线视频| 欧美成人一区二区三区| 久久99精品久久只有精品| 日韩一区二区免费在线电影| 蜜桃传媒麻豆第一区在线观看| 91久久香蕉国产日韩欧美9色| 一区二区三区在线视频播放| 99精品国产99久久久久久白柏| 国产精品久久久久一区| 99精品国产99久久久久久白柏| 亚洲免费在线观看| 色视频欧美一区二区三区| 亚洲精品国产视频| 欧美色图一区二区三区| 亚洲午夜精品一区二区三区他趣| 99r国产精品| 亚洲国产三级在线| 欧美日本国产一区| 香蕉加勒比综合久久| 欧美男生操女生| 久久99精品视频| 中文字幕一区二| 欧美午夜一区二区三区免费大片| 久久亚区不卡日本| av爱爱亚洲一区| 亚洲超碰97人人做人人爱| 欧美一级免费观看| 国产成人aaa| 亚洲一二三区视频在线观看| 成人v精品蜜桃久久一区| 亚洲精品乱码久久久久久黑人| 欧美三级三级三级| 成人免费高清在线|