网上已搜索golang pprof,资料很多,简明高效的一个没看到,这篇文章5步教你用会pprof获取cpu和内存prof。node
golang自带的prof包是runtime/pprof,这个是低级别的,须要你手动作一些设置等等周边工做,不利于咱们快速上手,利用pprof帮助咱们解决实际的问题。这里推荐davecheney封装的pprof,它能够1行代码,让你用上pprof,专心解决本身的代码问题,下载:git
go get github.com/pkg/profile
pprof生成的prof文件时二进制的,须要把这个二进制的文件转换为咱们人类可读的,graphviz能够帮助咱们把二进制的prof文件转换为图像。Mac安装:github
brew install graphviz
其余系统安装参考这里Graphviz Download。golang
只须要为hi.go
增长这一行,defer profile.Start().Stop()
,程序运行时,默认就会记录cpu数据:bash
package main import ( "fmt" "github.com/pkg/profile" ) func main() { defer profile.Start().Stop() sl := makeSlice() fmt.Printf("sum = %d\n", sumSlice(sl)) } func makeSlice() []int { sl := make([]int, 10000000) for idx := range sl { sl[idx] = idx } return sl } func sumSlice(sl []int) int { sum := 0 for _, x := range sl { sum += x } return sum }
编译和执行hi.go
。svg
go build hi.go ./hi
应当看到相似的结果,它输出了生成的cpu.pprof的路径:函数
2018/11/07 19:47:21 profile: cpu profiling enabled, /var/folders/5g/rz16gqtx3nsdfs7k8sb80jth0000gn/T/profile046201825/cpu.pprof sum = 49999995000000 2018/11/07 19:47:21 profile: cpu profiling disabled, /var/folders/5g/rz16gqtx3nsdfs7k8sb80jth0000gn/T/profile046201825/cpu.pprof
可视化有多种方式,能够转换为text、pdf、svg等等。text命令是ui
go tool pprof --text /path/to/yourbinary /var/path/to/cpu.pprof
结果是:spa
go tool pprof -text ./hi /var/folders/5g/rz16gqtx3nsdfs7k8sb80jth0000gn/T/profile046201825/cpu.pprof File: hi Type: cpu Time: Nov 7, 2018 at 7:47pm (CST) Duration: 202.18ms, Total samples = 50ms (24.73%) Showing nodes accounting for 50ms, 100% of 50ms total flat flat% sum% cum cum% 40ms 80.00% 80.00% 40ms 80.00% main.makeSlice /Users/shitaibin/go/src/github.com/shitaibin/awesome/hi.go 10ms 20.00% 100% 10ms 20.00% main.sumSlice /Users/shitaibin/go/src/github.com/shitaibin/awesome/hi.go 0 0% 100% 50ms 100% main.main /Users/shitaibin/go/src/github.com/shitaibin/awesome/hi.go 0 0% 100% 50ms 100% runtime.main /usr/local/go/src/runtime/proc.go
还有pdf这种效果更好:code
go tool pprof --pdf /path/to/yourbinary /var/path/to/cpu.pprof > cpu.pdf
例子:
go tool pprof -pdf ./hi /var/folders/5g/rz16gqtx3nsdfs7k8sb80jth0000gn/T/profile046201825/cpu.pprof > cpu.pdf
效果:
5步已经结束,你已经学会使用cpu pprof了吗?
若是你掌握了cpu pprof,mem pprof垂手可得就能拿下,只须要改1行代码:
defer profile.Start(profile.MemProfile).Stop()
效果:
go tool pprof -pdf ./hi /var/folders/5g/rz16gqtx3nsdfs7k8sb80jth0000gn/T/profile986580758/mem.pprof > mem.pdf
若是这篇文章对你有帮助,请点个赞/喜欢,让我知道个人写做是有价值的,感谢。