91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何理解Go語言的HTTP標準庫中的內存泄漏問題

發布時間:2021-11-17 14:50:50 來源:億速云 閱讀:289 作者:柒染 欄目:web開發

這篇文章給大家介紹如何理解Go語言的HTTP標準庫中的內存泄漏問題,內容非常詳細,感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。

使用一個go庫實現的一個http服務器:

package main           import (         "net/http"     )           func main() {         http.ListenAndServe(":8080", nil)     }

它將使用大約850kb的內存啟動.通過你的瀏覽器向它發送一些請求. 你會觀察到它(內存的使用)迅速上升到1mb.  如果你等著,你會發現它從來不會降下來. 現在(使用下面的腳本)用 Apache Bench 動一下它,你會發現內存使用仍然在增長.  一段時間過后它最終會維持在8.2mb左右

. Edit編輯: 看起來它并不會止步于8.2,而它的增長速度會顯著減慢。現在它處在9.2的水平,并且仍然在增長.

總之,為什么會發生這樣的事情呢?我使用了這段shell腳本一探究竟:

while [ true ]     do         ab -n 1000 -c 100 http://127.0.0.1:8080/         sleep 1     end

然后嘗試獲得這個的底線, 我已經嘗試過調整設置. 試過使用r.Close = true 來阻止 Keep-Alive. 沒有任何東西看起來是起作用的.

當我嘗試去判斷我正在編寫的程序是否存在內存泄露時,我發現了這個問題的來由. 它有大量的http處理器和I/O調用. 檢查過后我已經關閉了我所有的數據庫鏈接,我繼續觀察,仍然會看到內存使用繼續上升. 我的程序內存使用會維持在 433 MB 左右.

這里是 Goenv 的輸出:

GOARCH="amd64"     GOBIN=""     GOCHAR="6"     GOEXE=""     GOHOSTARCH="amd64"     GOHOSTOS="darwin"     GOOS="darwin"     GOPATH="/Users/mark/Documents/Programming/Go"     GORACE=""     GOROOT="/usr/local/go"     GOTOOLDIR="/usr/local/go/pkg/tool/darwin_amd64"     TERM="dumb"     CC="clang"     GOGCCFLAGS="-g -O2 -fPIC -m64 -pthread -fno-caret-diagnostics -Qunused-arguments -fno-common"     CXX="clang++"     CGO_ENABLED="1"

關于如何理解Go語言的HTTP標準庫中的內存泄漏問題就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

武穴市| 东方市| 琼海市| 苏州市| 尤溪县| 盐亭县| 怀化市| 舞钢市| 和平县| 稻城县| 临湘市| 华安县| 白朗县| 巴彦淖尔市| 忻州市| 虞城县| 乐昌市| 淳化县| 武乡县| 青阳县| 商城县| 平阳县| 仙居县| 苏尼特左旗| 湘乡市| 郁南县| 富阳市| 铜陵市| 上蔡县| 宿迁市| 汉中市| 汶上县| 承德县| 乌鲁木齐市| 石家庄市| 天峻县| 贡觉县| 盐池县| 鹤壁市| 益阳市| 灵石县|