欧美阿v视频在线大全_亚洲欧美中文日韩V在线观看_www性欧美日韩欧美91_亚洲欧美日韩久久精品

主頁 > 知識庫 > 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需要被關閉詳解的相關信息資訊供網民參考!
  • 推薦文章
    欧美阿v视频在线大全_亚洲欧美中文日韩V在线观看_www性欧美日韩欧美91_亚洲欧美日韩久久精品
  • <rt id="w000q"><acronym id="w000q"></acronym></rt>
  • <abbr id="w000q"></abbr>
    <rt id="w000q"></rt>
    国产亚洲精品aa| 国产 日韩 欧美大片| 欧美xxxx日本和非洲| 日本精品一区二区三区高清 | 99久久er热在这里只有精品66| 国产精品理论在线| 欧美精品一区二区在线播放| 久久www免费人成看片高清| 成人午夜剧场视频网站| 欧美变态口味重另类| 美女网站在线免费欧美精品| 精品无码一区二区三区| 精品入口麻豆88视频| 久久激五月天综合精品| 久久久视频6r| 国产调教视频一区| 国产91丝袜在线播放九色| caoporn91| 一区二区三区在线免费| 国产精品果冻传媒| 欧美一级精品大片| 美腿丝袜亚洲一区| 日韩黄色中文字幕| 中文字幕在线不卡| 精品人妻一区二区乱码| 91精品国产综合久久精品app | 国产女人aaa级久久久级| 国产精品一区久久久久| 四虎精品免费视频| 一区二区三区欧美日韩| 日本三级日本三级日本三级极| 欧美一卡2卡3卡4卡| 极品少妇一区二区三区精品视频| 国产不卡在线观看视频| 综合久久国产九一剧情麻豆| 91丨九色丨尤物| 欧美一区二区三级| 精品一区二区三区久久久| 波多野结衣喷潮| 一区二区三区色| 自拍视频一区二区| 国产丝袜在线精品| 91在线你懂得| 日韩免费看的电影| 国产91富婆露脸刺激对白| 欧美体内she精高潮| 欧美aaaaaa午夜精品| 天堂а√在线中文在线鲁大师| 亚洲色图视频网| 一区二区三区日韩精品视频| 超碰97在线资源站| 欧美国产一区视频在线观看| 韩国三级在线播放| 精品粉嫩超白一线天av| www.日韩精品| 欧美成人vps| 9i看片成人免费高清| 91精品国产综合久久久久久| 国产成人综合亚洲网站| 欧美人体做爰大胆视频| 国产精品中文字幕日韩精品| 欧美日韩精品系列| 国产一区 二区| 欧美日韩电影在线播放| 国产精一品亚洲二区在线视频| 欧美在线free| 国产在线视频一区二区| 欧美日韩午夜在线| 国产成人精品一区二| 制服丝袜中文字幕一区| 东方欧美亚洲色图在线| 日韩欧美在线影院| 91色九色蝌蚪| 国产亚洲综合av| av在线播放网址| 国产精品免费人成网站| 国产白嫩美女无套久久| 亚洲视频每日更新| 亚洲精品国产精品国自产网站| 亚洲一区二区三区在线看| www.99re6| 免费在线一区观看| 欧美视频一区在线| 国产成人在线网站| 精品久久久久久久久久久久久久久久久| 91原创在线视频| 国产女同性恋一区二区| 熟女少妇一区二区三区| 亚洲国产成人porn| 中文字幕另类日韩欧美亚洲嫩草| 久久精品国产在热久久| 欧美精品久久99| 99久精品国产| 国产女同性恋一区二区| 欧美 日韩 国产 成人 在线观看 | 黄页网站在线看| 国产精品视频第一区| 国产精品国产三级国产专业不| 五月婷婷色综合| 欧美午夜精品久久久久久超碰| 丰满白嫩尤物一区二区| 久久久国产午夜精品| 亚洲第一成人网站| 肉色丝袜一区二区| 欧美电影一区二区| 黑人巨大猛交丰满少妇| 亚洲欧洲av在线| 日韩av网站在线播放| 韩国精品一区二区| 日韩欧美综合一区| 小毛片在线观看| 亚洲成人动漫在线免费观看| 欧美午夜视频网站| 国产欧美日韩在线看| 三年中国中文观看免费播放| 日本午夜精品视频在线观看| 欧美疯狂做受xxxx富婆| 激情综合激情五月| 亚洲午夜在线电影| 精品视频在线免费观看| 初高中福利视频网站| 一区二区国产视频| 欧美三级日韩三级| 香蕉久久久久久av成人| 亚洲无线码一区二区三区| 欧美亚洲国产怡红院影院| 91免费小视频| 一片黄亚洲嫩模| 欧美久久一二区| 人妻体内射精一区二区三区| 天天综合日日夜夜精品| 欧美一区中文字幕| 波多野结衣福利| 精品一二线国产| 国产婷婷色一区二区三区在线| xxxxx99| 国产一区美女在线| 中文字幕电影一区| 色一区在线观看| 91麻豆国产精品久久| 亚洲国产一区二区视频| 欧美一区在线视频| 中文字幕在线观看免费高清| 国产精品99久久久久久似苏梦涵| 国产精品午夜在线| 成人羞羞国产免费图片| 91美女片黄在线观看| 亚洲成a人v欧美综合天堂| 欧美一区二区成人| 日本免费www| 成人免费看的视频| 夜夜揉揉日日人人青青一国产精品| 欧美日韩精品高清| 精品夜夜澡人妻无码av| 国产毛片精品一区| 亚洲少妇最新在线视频| 欧美日韩在线直播| 法国伦理少妇愉情| 国产69精品久久久久毛片| 亚洲免费在线视频| 欧美一区二区三区精品| 永久免费毛片在线观看| 成人av在线观| 偷窥少妇高潮呻吟av久久免费| 精品噜噜噜噜久久久久久久久试看| 中文字幕精品亚洲| 91丨porny丨在线| 日本成人中文字幕在线视频 | 国产91在线|亚洲| 一区二区三区欧美在线观看| 日韩三级免费观看| www.97视频| 中文字幕乱视频| 国产精品69毛片高清亚洲| 一区二区在线观看免费| 欧美电影精品一区二区| 在线观看亚洲网站| 中文字幕人妻一区二区三区| 国产精品一区在线观看乱码| 亚洲一区二区五区| 国产日韩欧美一区二区三区综合| 91国偷自产一区二区三区观看| av无码av天天av天天爽| 成人精品小蝌蚪| 免费欧美在线视频| 亚洲人成网站在线| 精品国产乱码久久久久久老虎| 色婷婷综合久久久久中文一区二区| 欧美xxxxx精品| 成人午夜视频免费看| 三级欧美在线一区| 亚洲视频在线一区| 久久综合色鬼综合色| 欧美日韩精品电影| 日韩国产第一页| 男女做爰猛烈刺激| 激情av中文字幕| 成人黄色软件下载| 久久99国产精品成人| 亚洲一区二区成人在线观看|