您好,登錄后才能下訂單哦!
之前一直研究過golang 的 pprof的性能分析,但是沒搞出火焰圖,后面查了一些資料學會了生成火焰圖。
今天我就用直接簡單暴力的方式的教程來說明怎么用Golang的pprof監控和生成火焰圖。
一.在代碼里面寫監聽接口口。
#必須要 import "net/http/pprof"
go func() {
if err := http.ListenAndServe("0.0.0.0:6060", nil); err != nil {
fmt.Println("0.0.0.0:6060", err.Error())
}
}()
如下圖所示:
二.運行程序。
三.查看pprof性能
① 訪問 http://localhost:6060/debug/pprof/
②如果你不想使用網頁的交互模式,可以再終端使用以下命令,當然每次都是新數據:
#查看堆信息
go tool pprof --text http://localhost:6060/debug/pprof/heap
結果如下:
一、Go torch
go-torch是Uber公司開源的一款針對Go語言程序的火焰圖生成工具,能收集 stack traces,并把它們整理成火焰圖,直觀地程序給開發人員。
go-torch是基于使用BrendanGregg創建的火焰圖工具生成直觀的圖像,很方便地分析Go的各個方法所占用的CPU的時間, 火焰圖是一個新的方法來可視化CPU的使用情況,本文中我會展示如何使用它輔助我們排查問題。
二、安裝
FlameGraph 是profile數據的可視化層工具,已被廣泛用于Python和Node
git clone https://github.com/brendangregg/FlameGraph.git
cp flamegraph.pl /usr/local/bin
有了flamegraph的支持,我們接下來要使用go-torch展示profile的輸出,而安裝go-torch很簡單,我們使用下面的命令即可完成安裝
go get -v github.com/uber/go-torch
①go-torch -h 查看幫助,如下:
② 程序跑起來,執行go-torch如下:
#采集60秒的數據,在當前目錄下生成cpu.svg文件
go-torch -u http://127.0.0.1:6060 --seconds 60 -f cpu.svg
③打開svg文件,查看火焰圖,如下:
參考文章:
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。