Profilage du nombre de goroutines avec pprof
La détection des fuites potentielles de goroutines 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 pour la détection des fuites. 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, facilitant ainsi la détection et la résolution des goroutines potentielles. fuites.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!