Rumah > pembangunan bahagian belakang > Golang > Tidak dapat mengosongkan penimbal bait memori

Tidak dapat mengosongkan penimbal bait memori

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
Lepaskan: 2024-02-06 09:51:03
ke hadapan
925 orang telah melayarinya

Tidak dapat mengosongkan penimbal bait memori

Kandungan soalan

pergi 1.18.1

laporan pprof

3549.93kb 49.73% 49.73%  3549.93kb 49.73%  src/lag_monitor.publishlagmetrictodatadog
     514kb  7.20% 56.93%      514kb  7.20%  bufio.newwritersize
  512.88kb  7.18% 64.11%   512.88kb  7.18%  encoding/pem.decode
  512.69kb  7.18% 71.30%  1536.98kb 21.53%  crypto/x509.parsecertificate
  512.50kb  7.18% 78.48%   512.50kb  7.18%  crypto/x509.(*certpool).addcert
Salin selepas log masuk

Kod ini nampaknya tidak melepaskan memori Menurut pprof, fungsi berikut adalah yang paling banyak menggunakan memori. peta ingatan

func caller() {
 events := make([]string, 0)
 //....
 PublishLagMetricToDataDog(ctx, strings.Join(events, ","))
}

func PublishLagMetricToDataDog(ctx context.Context, events string) error {
msg := `{
    "series": [%v]
}`
b := []byte(msg)
resp, err := http.Post("https://api.datadoghq.com/api/v1/series?api_key="+env.GetDataDogKey(), "application/json", bytes.NewBuffer(b))
if err != nil {
    logger.Error(ctx, "Error submitting event to datadog, err = ", err)
    return err
}
logger.Info(ctx, resp)
return nil
}
Salin selepas log masuk

Fungsi di atas dipanggil dalam gelung. Oleh kerana tiada pembolehubah global dan tiada rujukan kepada kepingan bait dalam publishlagmetrictodatadog, saya tidak dapat menentukan kebocoran memori. Saya membaca tentang reset() dan truncate() tetapi ini tidak membebaskan memori asas.


Jawapan Betul


Anda mesti menutup badan respons untuk setiap respons http yang anda terima. Kegagalan berbuat demikian boleh mengakibatkan kebocoran sumber, seperti yang anda perhatikan.

Penyelesaian:

    resp, err := http.Post("https://api.datadoghq.com/api/v1/series?api_key="+env.GetDataDogKey(), "application/json", bytes.NewBuffer(b))
    if err != nil {
        logger.Error(ctx, "Error submitting event to datadog, err = ", err)
        return err
    }
    logger.Info(ctx, resp)
    _ = resp.Body.Close() // <--- Add this
    return nil
}
Salin selepas log masuk

Atas ialah kandungan terperinci Tidak dapat mengosongkan penimbal bait memori. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:stackoverflow.com
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan