Rumah >pembangunan bahagian belakang >Golang >Tidak dapat mengosongkan penimbal bait memori
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.
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!