以下由golang教學專欄跟大家介紹golang cpu效能分析,希望對需要的朋友有幫助!
(1)time指令(linux系統下)
time go run a.go
real:從程式開始到結束,實際上度過的時間
user:程式在用戶態度過的時間
sys:程式在內核度過的時間
一般情況下,real>=user sys
(2) /usr/bin/time 指令(linux系統下)
/usr/bin/time -v go run a.go
該指令下可以看到cpu佔用率、 記憶體使用情況、進程切換狀況、檔案系統io、socket狀況
(1)在程式中引入 _ "net/http/pprof" ,並開啟pprof監聽
import _
http.ListenAndServe("0.0.0.0:10000", nil)
程序结束
通過瀏覽器查看CPU的信息和狀態
http://127.0.0.1:10000/debug/pprof
注意,等程序運⾏⼀定時間,再點擊profile⽂件⽣成(⾄少是30s)
(2)使用pprof
go tool pprof [binary] [profile] //binary二进制文件 profile 要分析的文件
top //查看当前profile文件的cpu使用率
flat 此函數⾃身程式碼的執⾏時⻓
flat% 此函數⾃身程式碼的執⾏時⻓佔⽤CPU的耗時百分⽐
cum 代表的是函數⾃身程式碼所有調⽤的函數的執⾏時⻓
cum% 代表的是函數⾃身程式碼所有調⽤的函式的執⾏時⻓,佔⽤CPU的總耗時百分⽐
sum% 每⼀⾏的flat%與上⾯所有⾏的flat%總和
(3)go tool pprof profile檔
啟動要偵錯的程序,在另一個終端執行go tool pprof http://localhost:10000/debug/pprof/profile?seconds=60
(4)視覺化結構圖
先在终端运行 go tool pprof [binary] [profile] ,然后输入web,浏览器会弹出一个可视化的图片。
更多相關技術文章,請造訪go語言教學欄位!
以上是關於golang cpu效能分析的詳細內容。更多資訊請關注PHP中文網其他相關文章!