Golang ialah bahasa berprestasi tinggi, serentak, tersusun Analisis prestasi sangat penting semasa menulis aplikasi berprestasi tinggi. Walaupun Golang mengambil kira perkara ini dalam reka bentuk awalnya, dalam persekitaran pengeluaran sebenar, beberapa alatan masih diperlukan untuk analisis prestasi. Satu alat yang sangat penting ialah pprof .
Nama penuh pprof ialah pemprofilan prestasi, iaitu alat analisis prestasi terbina dalam Golang. pprof boleh membantu pembangun menganalisis penggunaan CPU, penggunaan memori, dsb. semasa program dijalankan, untuk mencari kesesakan prestasi program.
prof berfungsi berdasarkan pensampelan. pprof akan mengumpul penggunaan CPU, penggunaan memori dan data lain aplikasi secara berkala apabila ia berjalan, dan kemudian menjana fail pensampelan (fail prof Pengguna boleh menggunakan fail ini untuk menganalisis prestasi program).
Untuk menggunakan pprof, kita perlu menambah beberapa coretan kod tertentu pada kod program. Coretan kod ini menangkap beberapa maklumat penting semasa program berjalan dan menulis maklumat ini ke dalam fail sampel. Selepas program berjalan, kita boleh menggunakan alat ppof alat go standard untuk menganalisis fail sampel.
Berikut ialah contoh penggunaan asas:
import ( "net/http" _ "net/http/pprof" ) func main() { go func() { http.ListenAndServe("localhost:6060", nil) }() // 代码片段 }
Dalam kod di atas, kami mengimport pakej net/http/pprof dan memulakan pelayan HTTP dalam fungsi utama untuk mendengar Permintaan daripada pprof. Kemudian, kami memasukkan beberapa coretan kod di lokasi utama dalam program. Coretan kod ini menangkap penggunaan CPU program, maklumat tindanan, dsb. dan menulis maklumat ini ke dalam fail sampel.
Apabila program selesai dijalankan, kita boleh menggunakan arahan berikut untuk memulakan alat pprof:
go tool pprof [binary] [profile]
Di mana [binary] ialah fail binari yang perlu dianalisis, [profile] ialah laluan ke fail pensampelan. Selepas memulakan alat pprof, anda boleh menggunakan arahan seperti top
, web
dan list
untuk melihat maklumat dalam fail pensampelan. Arahan
top
boleh melihat penggunaan CPU dan penggunaan memori program, dan menyusunnya mengikut penggunaan CPU: Perintah
(pprof) top Showing nodes accounting for 1030ms, 100% of 1030ms total Dropped 105 nodes (cum <= 5.15ms) Showing top 10 nodes out of 21 flat flat% sum% cum cum% 990ms 96.12% 96.12% 990ms 96.12% main.(*myStruct).doWork 20ms 1.94% 98.06% 20ms 1.94% time.Sleep 20ms 1.94% 100.00% 20ms 1.94% fmt.(*buffer).write 0 0% 100.00% 1030ms 100% runtime.main 0 0% 100.00% 1030ms 100% runtime.main.func1 0 0% 100.00% 1030ms 100% runtime.mstart 0 0% 100.00% 1030ms 100% runtime.mstart1 0 0% 100.00% 1030ms 100% runtime.systemstack 0 0% 100.00% 990ms 95.63% main.work 0 0% 100.00% 20ms 1.94% fmt.Fprintf
web
boleh menjana antara muka Web interaktif, lebih banyak lagi Paparkan secara visual kesesakan prestasi program: Perintah
(pprof) web
list
boleh melihat maklumat terperinci fungsi dan memaparkan kod sumber dan penggunaan CPU bagi fungsi:
(pprof) list myStruct.doWork Total: 1.03s ROUTINE ======================== main.(*myStruct).doWork in /path/to/main.go 990ms 990ms (flat, cum) 96.12% of Total 0 10ms 0.00% runtime.newstack 0 10ms 0.00% runtime.procresize 0 10ms 0.00% runtime.systemstack ...
pprof ialah alat analisis prestasi yang sangat praktikal boleh membantu pembangun mencari kesesakan prestasi aplikasi dengan cepat dan mengoptimumkannya. pprof ialah alat yang sangat diperlukan apabila kami menulis aplikasi berprestasi tinggi.
Atas ialah kandungan terperinci makna golang pprof. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!