首頁  >  文章  >  後端開發  >  為什麼 http post 請求在 go 中為我帶來很高的記憶體使用率?

為什麼 http post 請求在 go 中為我帶來很高的記憶體使用率?

PHPz
PHPz轉載
2024-02-14 15:24:08889瀏覽

为什么 http post 请求在 go 中给我带来很高的内存使用率?

php小編新一在使用Go語言進行http post請求時,發現高記憶體使用率的問題。這個問題引發了他的思考,為什麼會出現這樣的狀況?經過研究和分析,他找到了一些可能的原因,並提出了一些解決方案。在本文中,我們將深入探討這個問題並給予解答。

問題內容

我有一個 go 應用程式在 k8s 容器內運行。它作為一個 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)
        ...
    })
}


在上面的程式碼中,它監聽路徑 /logs 並呼叫 http 將資料儲存到 elasticsearch 中。當我使用下面的函數列印記憶體使用情況時,我可以看到 alloc 不斷增加,直到記憶體耗盡。如果我刪除 http.post 調用,記憶體使用量始終為 1 到 3mb。記憶體使用量不斷增加的原因可能是什麼?

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)
}

解決方法

http 文件多次提到:

客戶端完成後必須關閉回應正文:

這是文件中的範例:

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

如果你不這樣做,就會發生洩漏,因為主體將永遠保留在記憶體中。

以上是為什麼 http post 請求在 go 中為我帶來很高的記憶體使用率?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文轉載於:stackoverflow.com。如有侵權,請聯絡admin@php.cn刪除