Go 程序启用 pprof 分析 CPU 和内存热点只需两步:暴露 HTTP 分析端点(导入 ”net/http/pprof” 并启动:6060 服务)和用 go tool pprof 采集分析;CPU 用 profile?seconds=30 采样,内存用 heap 快照,支持 top、list、web 火焰图及 diff 对比。

直接在 Go 程序中启用 pprof 并分析 CPU 和内存 热点 ,核心就两步:暴露分析端点 + 用 go tool pprof 查看数据。不需要额外依赖,Go 自带 工具 链就能完成。
快速接入 HTTP 方式 pprof
适用于 Web 服务或可监听 端口 的长期运行程序。只需两处改动:
- 在
import块中添加匿名导入:_ "net/http/pprof" - 启动一个独立的 HTTP 服务(推荐用不同端口,如
:6060),避免干扰主业务
示例代码片段:
import ("log" "net/http" _ "net/http/pprof" // 自动注册 /debug/pprof/ 路由) func main() { // 单独起 goroutine 启动 pprof 服务 go func() {log.Println("pprof server started on :6060") log.Fatal(http.ListenAndServe("localhost:6060", nil)) }() // 主业务逻辑(比如 http.ListenAndServe(":8080", nil))}
启动后访问 https://www.php.cn/link/53d7f154d6c0738fa10f9402b2e93e96 就能看到所有可用分析项。
立即学习“go 语言免费学习笔记(深入)”;
采集并分析 CPU 热点
CPU profile 用于找出耗时最多的函数,定位计算瓶颈:
- 命令行采集 30 秒 CPU 数据:
go tool pprof https://www.php.cn/link/53d7f154d6c0738fa10f9402b2e93e96profile?seconds=30 - 进入交互界面后,输入
top查看前 10 名耗时函数 - 用
list 函数名查看该函数内部哪几行代码最热(比如循环体、频繁调用的子函数) - 输入
web可生成火焰图(需提前安装 Graphviz)
注意:默认采样是 wall-clock 时间,不是 CPU 时间;若程序大量休眠或阻塞,建议结合 block 或 goroutine profile 综合判断。
诊断内存分配与泄漏
内存分析重点看堆(heap)——即运行时动态分配的对象:
- 采集当前堆快照:
go tool pprof https://www.php.cn/link/53d7f154d6c0738fa10f9402b2e93e96heap - 常用命令:
top查分配量最大的函数;top -cum看调用链累计分配;list 函数名定位具体分配语句 - 对比多次采集结果更有效:比如在触发某操作前后各抓一次 heap,用
diff -base base.pprof找新增分配 - 关注
inuse_space(当前存活对象占用)和alloc_space(历史总分配量),前者高可能有泄漏,后者高说明分配频繁
补充:非 HTTP 场景的轻量采集
对 CLI 工具或短生命周期程序,可用 runtime/pprof 手动控制:
- 在关键代码段前后加
pprof.StartCPUProfile(f)和pprof.StopCPUProfile() - 或用
go test -bench . -cpuprofile cpu.pprof -memprofile mem.pprof对基准测试做分析 - 之后仍用
go tool pprof cpu.pprof或go tool pprof mem.pprof打开文件分析
不复杂但容易忽略:记得在采集期间让程序真实承载负载,空跑或低负载下 profile 结果意义不大。
以上就是如何使用 Golang 进行性能剖析_结合 pprof 分析 CPU 和内存