婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > golang中為什么Response.Body需要被關閉詳解

golang中為什么Response.Body需要被關閉詳解

熱門標簽:江西轉化率高的羿智云外呼系統 西部云谷一期地圖標注 地圖標注的汽車標 浙江高速公路地圖標注 中國地圖標注省會高清 廣州呼叫中心外呼系統 南通如皋申請開通400電話 學海導航地圖標注 高德地圖標注口訣

前言

本文主要介紹了關于golang中Response.Body需要被關閉的相關內容,文中通過示例代碼介紹的非常詳細,對各位學習或者使用golang具有一定參考學習價值,下面話不多說了,來一起看看詳細的介紹吧

Body io.ReadCloser

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 does not attempt to
reuse HTTP/1.0 or HTTP/1.1 TCP connections ("keep-alive") unless the Body is read to
completion and is closed.

http客戶端(Client)和傳輸(Transport)保證響應體總是非空的,即使響應沒有響應體或0長響應
體。關閉響應體是調用者的責任。默認http客戶端傳輸(Transport)不會嘗試復用keep-alive的
http/1.0、http/1.1連接,除非請求體已被完全讀出而且被關閉了。

以上是http包文檔說明。但是為什么body需要被關閉呢,不關閉會如何?那就讀源碼唄。

要了解body,首先要了解http事務是如何處理的。http事務是交由底層的Transport處理的。

第一步是從連接池獲取一個連接,這個連接的功能由3個goroutine協同實現,一個主goroutine,一個readLoop,一個writeLoop,后兩個goroutine生命周期和連接一致。雖說readLoop和writeLoop名字叫循環(也確實是for循環),但實際上一次循環就完整處理一個http事務,循環本身僅僅是為了連接復用,所以為了便于理解其邏輯可以忽略它的循環結構。

接下來三個goroutine協同完成http事務:

  • 主goroutine將request同時發給readLoop和writeLoop。
  • writeLoop發送request,然后將狀態(error)發送給主goroutine和readLoop。
  • readLoop解析頭部response,然后將狀態(error)和response發送給主goroutine。
  • 主goroutine返回用戶代碼,readLoop等待body讀取完成。
  • readLoop回收連接。

了解http事務的處理流程,然后我們回過頭來看看神秘的body到底是什么

//源碼版本1.8.3
// src/net/http/transfer.go:405 body解析方法
func readTransfer(msg interface{}, r *bufio.Reader) (err error)

// src/net/http/transfer.go:485 解析chunked
t.Body = body{src: internal.NewChunkedReader(r), hdr: msg, r: r, closing: t.Close}

// src/net/http/transfer.go:490 產生eof
t.Body = body{src: io.LimitReader(r, realLength), closing: t.Close}

// src/net/http/transport.go:1560 發送eof信號
body := bodyEOFSignal{

// src/net/http/transport.go:1583 gzip解碼
resp.Body = gzipReader{body: body}

body實際上是一個嵌套了多層的net.TCPConn:

  • bufio.Reader,這層嘗試將多次小的讀操作替換為一次大的讀操作,減少系統調用的次數,提高性能;
  • io.LimitedReader,tcp連接在讀取完body后不會關閉,繼續讀會導致阻塞,所以需要LimitedReader在body讀完后發出eof終止讀取;
  • chunkedReader,解析chunked格式編碼(如果不是chunked略過);
  • bodyEOFSignal,在讀到eof,或者是提前關閉body時會對readLoop發出回收連接的通知;
  • gzipReader,解析gzip壓縮(如果不是gizp壓縮略過);

從上面可以看出如果body既沒有被完全讀取,也沒有被關閉,那么這次http事務就沒有完成,除非連接因超時終止了,否則相關資源無法被回收。

如果請求頭或響應頭指明Connection: close呢?還是無法回收,因為close表示在http事務完成后斷開連接,而事務尚未完成自然不會斷開,更不會回收。

從實現上看只要body被讀完,連接就能被回收,只有需要拋棄body時才需要close,似乎不關閉也可以。但那些正常情況能讀完的body,即第一種情況,在出現錯誤時就不會被讀完,即轉為第二種情況。而分情況處理則增加了維護者的心智負擔,所以始終close body是最佳選擇。

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。

您可能感興趣的文章:
  • golang設置http response響應頭與填坑記錄
  • 解決golang處理http response碰到的問題和需要注意的點
  • 解決Golang中ResponseWriter的一個坑

標簽:許昌 常州 曲靖 吐魯番 東營 德宏 貴州 保定

巨人網絡通訊聲明:本文標題《golang中為什么Response.Body需要被關閉詳解》,本文關鍵詞  golang,中,為什么,Response.Body,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《golang中為什么Response.Body需要被關閉詳解》相關的同類信息!
  • 本頁收集關于golang中為什么Response.Body需要被關閉詳解的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    国产亚洲欧美色| 免费观看在线综合| 国产91富婆露脸刺激对白| 亚洲一区二区四区蜜桃| 国产精品私人自拍| 欧美激情一区二区三区不卡| 欧美成人综合网站| 欧美日韩国产高清一区二区三区| 91香蕉视频mp4| av一二三不卡影片| av电影在线不卡| 色综合天天综合| 337p亚洲精品色噜噜狠狠| 精品国产凹凸成av人导航| 欧美一区二区三区人| 欧美三级中文字幕在线观看| 777xxx欧美| 亚洲视频中文字幕| 美女性感视频久久| hitomi一区二区三区精品| 色婷婷av一区二区三区大白胸| 欧美日韩久久久| 中文字幕高清一区| 日韩二区三区四区| 91麻豆免费观看| 中文字幕av资源一区| 午夜伊人狠狠久久| 日本高清不卡在线观看| 国产精品免费网站在线观看| 日韩电影在线观看电影| 色婷婷av久久久久久久| 国产日韩欧美亚洲| 国产成人综合网| 欧美精品一区二区三区视频| 中文字幕一区二区三区色视频| 中文字幕一区二区三区蜜月 | 亚洲在线视频网站| 亚洲国产精品一区二区www在线| 欧美aaa在线| 欧美人动与zoxxxx乱| 国产精品国产三级国产三级人妇| 国产日本亚洲高清| 国产成人精品免费一区二区| 日韩欧美激情在线| 午夜成人免费视频| 欧美三级视频在线观看| 午夜免费久久看| 亚洲视频中文字幕| 成人网页在线观看| 亚洲色图.com| 欧美性猛交xxxxxxxx| 久久精品av麻豆的观看方式| 日韩精品一区二区三区中文精品 | 亚洲精品高清在线| 色久优优欧美色久优优| 日韩在线播放一区二区| 久久久久久久av麻豆果冻| 99久久免费精品高清特色大片| 亚洲线精品一区二区三区八戒| 精品国产制服丝袜高跟| 成人精品小蝌蚪| 麻豆免费看一区二区三区| 亚洲欧美另类久久久精品2019| 欧美一区二区视频在线观看| 波多野结衣一区二区三区| 日本亚洲三级在线| 亚洲精品videosex极品| 亚洲国产精品av| 欧美一级二级在线观看| 91久久线看在观草草青青| 91久久人澡人人添人人爽欧美| 一区二区三区产品免费精品久久75| 欧美中文字幕亚洲一区二区va在线 | 亚洲天堂精品在线观看| 欧美一级理论片| 欧美一区二区三区影视| 欧洲色大大久久| 欧美色图片你懂的| 94-欧美-setu| 成人性生交大合| 国产成人高清视频| 成人91在线观看| 99国产精品一区| 色偷偷一区二区三区| 97精品国产97久久久久久久久久久久| 国产成a人亚洲精| 成人aa视频在线观看| 91麻豆国产福利在线观看| av不卡在线播放| www.一区二区| 91网站黄www| 在线成人高清不卡| 国产欧美视频一区二区| 午夜在线成人av| 91麻豆国产福利在线观看| 色综合中文字幕| 欧美精品久久久久久久久老牛影院| 欧美精品三级在线观看| 精品欧美久久久| 亚洲精品高清在线| 久久国产视频网| 99国产一区二区三精品乱码| 欧洲另类一二三四区| 精品久久久久av影院| 中文字幕制服丝袜一区二区三区| 午夜视频一区在线观看| 成人av在线播放网站| 26uuu久久综合| 日韩在线观看一区二区| 在线观看日韩一区| 国产视频在线观看一区二区三区| 国产精品久久久久7777按摩| 国产精品久久久久久久久动漫| 午夜日韩在线观看| av福利精品导航| 国产亚洲综合在线| 久久精品国产色蜜蜜麻豆| 91麻豆国产自产在线观看| 国产女同性恋一区二区| 麻豆中文一区二区| 日本韩国一区二区| 国产精品传媒入口麻豆| 国产福利精品导航| 91麻豆精品91久久久久久清纯| 欧美国产日韩在线观看| 国产精品18久久久久久vr| 欧美成人在线直播| 久久99久久99| 日本一区二区视频在线观看| av不卡免费在线观看| 亚洲国产精品一区二区www在线| 欧美日韩一区高清| 美女脱光内衣内裤视频久久影院| 精品国产乱码久久久久久老虎| 极品少妇xxxx精品少妇| 日韩精品成人一区二区在线| 欧美顶级少妇做爰| 成人性生交大片| 三级精品在线观看| 久久蜜桃一区二区| 色天天综合久久久久综合片| 奇米一区二区三区| 日韩美女啊v在线免费观看| 欧美日韩一区二区在线观看| 精品一区二区精品| 天天色图综合网| 亚洲人成影院在线观看| 日韩一二三区视频| 欧美性videosxxxxx| 99久久精品免费看国产| 国产一区二区三区香蕉| 亚洲最新视频在线播放| 日韩欧美二区三区| av电影在线观看一区| 国产二区国产一区在线观看| 亚洲va在线va天堂| 亚洲激情图片一区| 最新日韩在线视频| 亚洲视频免费在线| 国产精品久久久久影院亚瑟| 久久蜜桃av一区二区天堂| 91精品在线一区二区| 日韩欧美国产一区在线观看| 91精品国产综合久久小美女| 欧美一区二区在线免费播放| 欧美无乱码久久久免费午夜一区| 欧洲av一区二区嗯嗯嗯啊| 在线观看视频91| 欧美男女性生活在线直播观看| 色哟哟欧美精品| 欧美日韩亚洲不卡| 欧美不卡在线视频| 久久精品视频免费| 欧美激情中文不卡| 一区二区三区不卡视频| 视频在线在亚洲| 国产精品影视在线| 91国产丝袜在线播放| 911国产精品| 久久久久久免费毛片精品| 中文字幕av资源一区| 亚洲国产裸拍裸体视频在线观看乱了| 久久精品国产在热久久| 国产精品一区二区x88av| 日本伦理一区二区| 精品日韩一区二区三区| 亚洲精品久久嫩草网站秘色| 狠狠色丁香久久婷婷综合_中 | 欧美电影一区二区三区| 久久亚洲捆绑美女| 亚洲综合免费观看高清完整版| 美日韩一区二区三区| 91丝袜国产在线播放| 久久婷婷国产综合国色天香| 亚洲精品亚洲人成人网| 国产一区二区h| 精品国产欧美一区二区| 亚洲一区二区三区爽爽爽爽爽 | 久久久影视传媒| 日本特黄久久久高潮|