Profilage du nombre de goroutines avec pprof
La détection des fuites de goroutines potentielles dans votre programme Go nécessite de surveiller le nombre de goroutines actives au fil du temps. Bien que la commande pprof standard de l'outil go fournisse des informations sur le blocage, elle ne traite pas directement du nombre de goroutines.
Pour profiler efficacement le nombre de goroutines, ouvrez http://localhost:8888/debug/pprof/ dans votre navigateur. . Celui-ci présente deux liens pertinents :
Le lien Goroutine affiche les goroutines partageant le même code que les simples entrées, ainsi que leur décompte. Par exemple :
1 @ 0x42f223 0x42f2e4 0x40542f 0x404f4b 0x4a0586 0x4600a1 # 0x4a0586 gitlab.com/gitlab-org/gitlab-ci-multi-runner/commands.(*RunCommand).startWorkers 0x56 /home/me/go/src/gitlab.com/gitlab-org/gitlab-ci-multi-runner/commands/multi.go:164 1 @ 0x42f223 0x43dfd7 0x43d532 0x4a04ed 0x4600a1 # 0x4a04ed gitlab.com/gitlab-org/gitlab-ci-multi-runner/commands.(*RunCommand).processRunners 0x45d /home/me/go/src/gitlab.com/gitlab-org/gitlab-ci-multi-runner/commands/multi.go:147
Le chiffre 1 avant le @ indique une instance de chaque goroutine.
Le Full Goroutine Stack Dump est particulièrement utile en cas de fuite détection. Il répertorie chaque goroutine individuellement, y compris sa trace de pile et son statut d'activité :
goroutine 49 [chan receive, 2 minutes]: gitlab.com/gitlab-org/gitlab-ci-multi-runner/commands.(*RunCommand).startWorkers(0xc820103ee0, 0xc820274000, 0xc820274060, 0xc8201d65a0) /home/me/go/src/gitlab.com/gitlab-org/gitlab-ci-multi-runner/commands/multi.go:164 0x56 created by gitlab.com/gitlab-org/gitlab-ci-multi-runner/commands.(*RunCommand).Run /home/me/go/src/gitlab.com/gitlab-org/gitlab-ci-multi-runner/commands/multi.go:294 0x41b goroutine 50 [select]: gitlab.com/gitlab-org/gitlab-ci-multi-runner/commands.(*RunCommand).processRunners(0xc820103ee0, 0x0, 0xc820274060, 0xc8201d65a0) /home/me/go/src/gitlab.com/gitlab-org/gitlab-ci-multi-runner/commands/multi.go:147 0x45d created by gitlab.com/gitlab-org/gitlab-ci-multi-runner/commands.(*RunCommand).startWorkers /home/me/go/src/gitlab.com/gitlab-org/gitlab-ci-multi-runner/commands/multi.go:165 0x96
En utilisant ces points de terminaison pprof, vous pouvez surveiller efficacement le nombre de goroutines au sein de votre programme, aidant à la détection et à la résolution des fuites potentielles de goroutines.
Clause de non-responsabilité: Toutes les ressources fournies proviennent en partie d'Internet. En cas de violation de vos droits d'auteur ou d'autres droits et intérêts, veuillez expliquer les raisons détaillées et fournir une preuve du droit d'auteur ou des droits et intérêts, puis l'envoyer à l'adresse e-mail : [email protected]. Nous nous en occuperons pour vous dans les plus brefs délais.
Copyright© 2022 湘ICP备2022001581号-3