日日操夜夜添-日日操影院-日日草夜夜操-日日干干-精品一区二区三区波多野结衣-精品一区二区三区高清免费不卡

公告:魔扣目錄網(wǎng)為廣大站長提供免費收錄網(wǎng)站服務(wù),提交前請做好本站友鏈:【 網(wǎng)站目錄:http://www.ylptlb.cn 】, 免友鏈快審服務(wù)(50元/站),

點擊這里在線咨詢客服
新站提交
  • 網(wǎng)站:51998
  • 待審:31
  • 小程序:12
  • 文章:1030137
  • 會員:747

php小編新一在使用Go語言進行http post請求時,發(fā)現(xiàn)高內(nèi)存使用率的問題。這個問題引發(fā)了他的思考,為什么會出現(xiàn)這樣的情況?經(jīng)過調(diào)研和分析,他找到了一些可能的原因,并提出了一些解決方案。在本文中,我們將深入探討這個問題并給出解答。

問題內(nèi)容

我有一個 go 應(yīng)用程序在 k8s 容器內(nèi)運行。它作為一個 rest api 工作,接收請求并將它們的請求寫入 elasticsearch。

我的代碼是:

var r = gin.default()
r.post("/logs", func(c *gin.context) {
        fmt.println("receive log event")
        printmemusage()
        jsondata, err := ioutil.readall(c.request.body)
        d := strings.newreader(jsondata)
        http.post(fmt.sprintf("%s/_bulk", geteshost()), "application/json", d)
        ...
    })
}


登錄后復(fù)制

在上面的代碼中,它監(jiān)聽路徑 /logs 并調(diào)用 http 將數(shù)據(jù)保存到 elasticsearch 中。當我使用下面的函數(shù)打印內(nèi)存使用情況時,我可以看到 alloc 不斷增加,直到內(nèi)存耗盡。如果我刪除 http.post 調(diào)用,內(nèi)存使用量始終為 1 到 3mb。內(nèi)存使用量不斷增加的原因可能是什么?

func bToMb(b uint64) uint64 {
    return b / 1024 / 1024
}
func PrintMemUsage() {
    var m runtime.MemStats
    runtime.ReadMemStats(&m)
    // For info on each, see: https://golang.org/pkg/runtime/#MemStats
    fmt.Printf("Alloc = %v MiB", bToMb(m.Alloc))
    fmt.Printf("\tTotalAlloc = %v MiB", bToMb(m.TotalAlloc))
    fmt.Printf("\tSys = %v MiB", bToMb(m.Sys))
    fmt.Printf("\tNumGC = %v\n", m.NumGC)
}

登錄后復(fù)制

解決方法

http 文檔多次提到:

客戶端完成后必須關(guān)閉響應(yīng)正文:

這是文檔中的示例:

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

登錄后復(fù)制

如果你不這樣做,就會發(fā)生泄漏,因為主體將永遠保留在內(nèi)存中。

分享到:
標簽:Go語言
用戶無頭像

網(wǎng)友整理

注冊時間:

網(wǎng)站:5 個   小程序:0 個  文章:12 篇

  • 51998

    網(wǎng)站

  • 12

    小程序

  • 1030137

    文章

  • 747

    會員

趕快注冊賬號,推廣您的網(wǎng)站吧!
最新入駐小程序

數(shù)獨大挑戰(zhàn)2018-06-03

數(shù)獨一種數(shù)學(xué)游戲,玩家需要根據(jù)9

答題星2018-06-03

您可以通過答題星輕松地創(chuàng)建試卷

全階人生考試2018-06-03

各種考試題,題庫,初中,高中,大學(xué)四六

運動步數(shù)有氧達人2018-06-03

記錄運動步數(shù),積累氧氣值。還可偷

每日養(yǎng)生app2018-06-03

每日養(yǎng)生,天天健康

體育訓(xùn)練成績評定2018-06-03

通用課目體育訓(xùn)練成績評定