Maison  >  Article  >  développement back-end  >  Comment utiliser le package pprof de Golang pour effectuer une analyse des performances des programmes

Comment utiliser le package pprof de Golang pour effectuer une analyse des performances des programmes

藏色散人
藏色散人avant
2020-11-25 15:12:022725parcourir

La colonne tutorielle suivante de golang vous présentera comment utiliser le package pprof de golang pour effectuer une analyse des performances du programme. J'espère que cela sera utile aux amis dans le besoin !

Comment utiliser le package pprof de Golang pour effectuer une analyse des performances des programmes

golang fournit le package pprof, qui peut surveiller la pile du programme golang, la consommation de temps du processeur et d'autres informations sur les performances. Parlons de l'utilisation de ce package pprof.
1. Le premier est l'introduction. Il peut être introduit à deux endroits :

“net/http/pprof”
 "runtime/prof"

Parmi eux, "net/http/pprof" est packagé avec "runtime/pprof", puis le port http est exposé Sortez, afin que nous puissions visualiser l'analyse des performances du programme dans le navigateur. "runtime/pprof" peut générer des fichiers *.pprof, puis effectuer une analyse des performances basée sur ce fichier
2. Utilisez ensuite pprof dans le code. Il existe trois situations dans l'application réelle :
1)
. Si le programme lui-même est un serveur Web, il vous suffit d'introduire pprof via le code :

import(
_"net/http/pprof"
 )

, puis de visiter http://localhost:port/debug/pprof/ dans le navigateur pour voir L'état actuel du service Web, y compris l'utilisation du processeur et de la mémoire, etc.
2)
Si votre programme go n'est pas un serveur Web, mais un processus de service, vous devez alors ouvrir une goroutine pour activer l'écoute des ports.
Par exemple :

go func() {
         log.Println(http.ListenAndServe("localhost:6060", nil)) 
 }()

Visitez également http://localhost:6060/debug/pprof pour afficher les informations sur l'exécution du programme.
3) Si votre programme n'est qu'une application, alors vous devez utiliser le package "runtime/ppprof".
Le code donné par le site officiel est comme ceci :

var cpuprofile = flag.String("cpuprofile", "", "write cpu profile to file")
 func main() {
     flag.Parse()
     if *cpuprofile != "" {
         f, err := os.Create(*cpuprofile)
         if err != nil {
             log.Fatal(err)
         }
         pprof.StartCPUProfile(f)
         defer pprof.StopCPUProfile()
     }

, et puis quand on lance ce programme, on ajoute un paramètre --cpuprofile=*.prof pour en générer un dans le correspondant répertoire.pprof, les informations sur le programme en cours d'exécution se trouvent toutes dans ce fichier. Entrez ensuite le répertoire correspondant et exécutez la commande : go tool pprof Ajoutez le nom du fichier pprof qui vient d'être généré pour saisir pprof Entrez la commande web pour générer le fichier svg correspondant.

Deuxième méthode :
Lors de l'utilisation du package "net/http/pprof", nous pouvons également utiliser la commande go tool pprof pour afficher l'état d'exécution du programme. Par exemple, si nous démarrons un simple programme serveur go et écoutons sur le port 8080, nous pouvons utiliser la commande suivante pour entrer la ligne de commande de pprof :
Utilisez cette commande pour afficher les informations sur la pile :

go tool pprof http://localhost:6060/debug/pprof/heap
 利用这个命令可以查看程序CPU使用情况信息:
 go tool pprof http://localhost:6060/debug/pprof/profile
 使用这个命令可以查看block信息:
 go tool pprof http://localhost:6060/debug/pprof/block
 进入pprof命令行,输入help,查看命令帮助,
 topN命令可以查看占用前N 的线程或者函数,用svg可以生成svg图。
 pprof简单使用就是这样了,掌握了使用方法,在实践中加以利用才是我们的目的,希望我写的这些可以对你有所帮助。

ps ; Parce que je n'ai jamais vraiment écrit de programme à grande échelle en golang, et que je n'ai pas non plus vraiment utilisé ce package, je viens de lire quelques articles et de résumer certaines informations sur le site officiel. les erreurs. Les corrections sont les bienvenues ! Merci

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!

Déclaration:
Cet article est reproduit dans:. en cas de violation, veuillez contacter admin@php.cn Supprimer