So verwenden Sie das pprof-Paket von Golang, um eine Leistungsanalyse für Programme durchzuführen

藏色散人
Freigeben: 2020-11-25 15:12:02
nach vorne
2797 Leute haben es durchsucht

In der folgenden Tutorial-Kolumne von golang erfahren Sie, wie Sie das pprof-Paket von Golang verwenden, um eine Leistungsanalyse für das Programm durchzuführen. Ich hoffe, dass es für Freunde in Not hilfreich ist!

So verwenden Sie das pprof-Paket von Golang, um eine Leistungsanalyse für Programme durchzuführen

golang stellt das pprof-Paket bereit, mit dem der Stapel von Golang-Programmen, die CPU-Zeit und andere Leistungsinformationen überwacht werden können. Lassen Sie uns über die Verwendung dieses pprof-Pakets sprechen.
1. Die erste ist die Einführung. Sie kann an zwei Stellen eingeführt werden:

“net/http/pprof”
 "runtime/prof"
Nach dem Login kopieren

Unter ihnen wird „net/http/pprof“ mit „runtime/pprof“ gepackt und dann wird der http-Port verfügbar gemacht Wir können den Browser verwenden, um die Leistungsanalyse des Programms anzuzeigen. „runtime/pprof“ kann *.pprof-Dateien generieren und dann eine Leistungsanalyse basierend auf dieser Datei durchführen
2. Dann gibt es bei der tatsächlichen Verwendung drei Situationen:
1)
Wenn das Programm selbst ein Webserver, dann müssen Sie pprof nur über den Code einführen:

import(
_"net/http/pprof"
 )
Nach dem Login kopieren

und dann http://localhost:port/debug/pprof/ im Browser besuchen, um den Status des aktuellen Webdienstes, einschließlich der CPU-Auslastung, anzuzeigen und Speichernutzung usw.
2)
Wenn Ihr Go-Programm kein Webserver, sondern ein Dienstprozess ist, müssen Sie eine Goroutine öffnen, um das Port-Listening zu aktivieren.
Zum Beispiel:

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

Besuchen Sie auf ähnliche Weise http://localhost:6060/debug/pprof, um Informationen zur Programmausführung anzuzeigen.
3) Wenn Ihr Programm nur eine Anwendung ist, müssen Sie das Paket „runtime/ppprof“ verwenden.
Der auf der offiziellen Website bereitgestellte Code lautet wie folgt:

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()
     }
Nach dem Login kopieren

Wenn wir dieses Programm ausführen, fügen wir einen Parameter hinzu: cpuprofile=*.prof, um eine .pprof-Datei im entsprechenden Verzeichnis zu generieren, und das Programm wird ausgeführt Die Informationen befinden sich alle in dieser Datei. Geben Sie dann das entsprechende Verzeichnis ein und führen Sie den Befehl go tool pprof aus. Fügen Sie den gerade generierten pprof-Dateinamen hinzu, um den Webbefehl einzugeben, um die entsprechende SVG-Datei zu generieren.

Zweite Methode:
Bei Verwendung des Pakets „net/http/pprof“ können wir auch den Befehl go tool pprof verwenden, um den Ausführungsstatus des Programms anzuzeigen. Wenn wir beispielsweise ein einfaches Go-Server-Programm starten und Port 8080 abhören, können wir den folgenden Befehl verwenden, um die Befehlszeile von pprof einzugeben:
Verwenden Sie diesen Befehl, um die Stapelinformationen anzuzeigen:

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简单使用就是这样了,掌握了使用方法,在实践中加以利用才是我们的目的,希望我写的这些可以对你有所帮助。
Nach dem Login kopieren

ps; Ich habe es nicht wirklich verwendet, aber ich habe dieses Paket nie wirklich verwendet. Ich habe nur ein paar Artikel gelesen und einige Informationen auf der offiziellen Website zusammengefasst. Es ist unvermeidlich, dass ich metaphysische Fehler mache sind herzlich willkommen! Danke

Das obige ist der detaillierte Inhalt vonSo verwenden Sie das pprof-Paket von Golang, um eine Leistungsanalyse für Programme durchzuführen. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Quelle:csdn.net
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage