首頁 > 後端開發 > Golang > 關於golang cpu效能分析

關於golang cpu效能分析

藏色散人
發布: 2020-12-25 16:04:18
轉載
3149 人瀏覽過

以下由golang教學專欄跟大家介紹golang cpu效能分析,希望對需要的朋友有幫助!

關於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狀況

二.golang下cpu效能分析

(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中文網其他相關文章!

相關標籤:
來源:cnblogs.com
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板