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

Tidak dapat mengosongkan penimbal bait memori

WBOY
WBOYke hadapan
2024-02-06 09:51:03855semak imbas

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

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
}

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
}

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

Kenyataan:
Artikel ini dikembalikan pada:stackoverflow.com. Jika ada pelanggaran, sila hubungi admin@php.cn Padam