Golang pprof详解
go的pprof包
go中有pprof包来做代码的性能监控,在两个地方有包:
net/http/pprof
runtime/pprof
其实net/http/pprof中只是使用runtime/pprof包来进行封装了一下,并在http端口上暴露出来.
本篇只讲如何在web上查看性能。
一、代码部分
1.import 增加net/http/pprof包
import( _ net/http/pprof )
2. 打开http 监听端口
go func() { log.Println(http.ListenAndServe("localhost:10000", nil)) }()
二、网页上查看
*浏览器可以打开 http://127.0.0.1:10000/debug/pprof/ 可以查看各种profile索引
1.如果安装过graphviz直接提交过这步骤,否则可以到 http://www.graphviz.org/download/下载,并把bin加入到环境变量
2.查看profile :在命令行输入
1 | go tool pprof http: //localhost:10000/debug/pprof/profile |
此后的30秒进入收集profile信息的状态。
30秒后进入pprof的交互模式,然后输入
1 | web |
然后浏览器自动弹开到网页展示svg图
3.查看已经保存的profile文件
1 | go tool pprof profile C:\Users\user\pprof\pprof.samples.cpu.004.pb.gz |
然后也是进入pprof的交互模式,然后输入web
还可以查看heap和goroutine
1 2 | go tool pprof http: //localhost:10000/debug/pprof/heap go tool pprof http: //127.0.0.1:10000/debug/pprof/goroutine |
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】凌霞软件回馈社区,携手博客园推出1Panel与Halo联合会员
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 如何统计不同电话号码的个数?—位图法
· C#高性能开发之类型系统:从 C# 7.0 到 C# 14 的类型系统演进全景
· 从零实现富文本编辑器#3-基于Delta的线性数据结构模型
· 记一次 .NET某旅行社酒店管理系统 卡死分析
· 长文讲解 MCP 和案例实战
· 用c#从头写一个AI agent,实现企业内部自然语言数据统计分析
· 三维装箱问题(3D Bin Packing Problem, 3D-BPP)
· Windows上,10分钟构建一个本地知识库
· 容器化 MCP Server!
· Java虚拟机代码是如何一步一步变复杂且难以理解的?