golang pprof操作流程


安装 graphviz
brew install graphviz // for macos
apt install graphviz   // for ubuntu
yum install graphviz  // for centos

设置svg文件默认打开程序
右键svg文件 ->显示简介->默认程序

//main.go 文件
package main

import (
// 略
_ "net/http/pprof" // 会自动注册 handler 到 http server,方便通过 http 接口获取程序运行采样报告
// 略
)

func main() {
// 略

runtime.GOMAXPROCS(1) // 限制 CPU 使用数,避免过载
runtime.SetMutexProfileFraction(1) // 开启对锁调用的跟踪
runtime.SetBlockProfileRate(1) // 开启对阻塞操作的跟踪

go func() {
// 启动一个 http server,注意 pprof 相关的 handler 已经自动注册过了
if err := http.ListenAndServe(":6060", nil); err != nil {
log.Fatal(err)
}
os.Exit(0)
}()

// 略
}


打开浏览器访问 http://localhost:6060/debug/pprof/
交互式终端
go tool pprof http://localhost:6060/debug/pprof/profile
go tool pprof http://localhost:6060/debug/pprof/heap
go tool pprof http://localhost:6060/debug/pprof/allocs
go tool pprof http://localhost:6060/debug/pprof/goroutine
go tool pprof http://localhost:6060/debug/pprof/mutex
go tool pprof http://localhost:6060/debug/pprof/block

命令: top/list/web

火焰图
go tool pprof -http=:8081 ~/pprof/[文件路径名].pb.gz

内存记录工具 prog_mem.sh

#!/bin/bash
prog_name="your_programe_name"
prog_mem=$(pidstat -r -u -h -C $prog_name |awk 'NR==4{print $12}')
time=$(date "+%Y-%m-%d %H:%M:%S")
echo $time"\tmemory(Byte)\t"$prog_mem >>~/record/prog_mem.log

使用crontab建立定时任务,每分钟记录1次。使用crontab -e编辑crontab配置,在最后增加1行:
*/1 * * * * ~/record/prog_mem.sh

脚本输出的内容保存在prog_mem.log。如果需要可视化,可以直接黏贴prog_mem.log内容到Excel等表格工具,绘制内存占用图

参考链接

https://blog.wolfogre.com/posts/go-ppof-practice/
https://book.eddycjy.com/golang/tools/go-tool-pprof.html
https://segmentfault.com/a/1190000019222661


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM