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

關於golang cpu效能分析

藏色散人
藏色散人轉載
2020-12-25 16:04:183025瀏覽

以下由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刪除