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

  

posted @   MrBlue  阅读(6667)  评论(0)    收藏  举报
编辑推荐:
· 如何统计不同电话号码的个数?—位图法
· C#高性能开发之类型系统:从 C# 7.0 到 C# 14 的类型系统演进全景
· 从零实现富文本编辑器#3-基于Delta的线性数据结构模型
· 记一次 .NET某旅行社酒店管理系统 卡死分析
· 长文讲解 MCP 和案例实战
阅读排行:
· 用c#从头写一个AI agent,实现企业内部自然语言数据统计分析
· 三维装箱问题(3D Bin Packing Problem, 3D-BPP)
· Windows上,10分钟构建一个本地知识库
· 容器化 MCP Server!
· Java虚拟机代码是如何一步一步变复杂且难以理解的?
点击右上角即可分享
微信分享提示