0

0

如何在Golang中使用pprof进行性能分析_生成CPU和内存分析报告

P粉602998670

P粉602998670

发布时间:2025-12-27 18:09:38

|

513人浏览过

|

来源于php中文网

原创

Go中pprof性能分析需启动HTTP服务暴露接口,CPU分析持续采样30秒获取热点函数,内存分析区分allocs(累计分配)和inuse_space(当前占用),支持在线采集、离线分析及火焰图生成。

如何在golang中使用pprof进行性能分析_生成cpu和内存分析报告

在 Go 中使用 pprof 做性能分析非常直接,核心是启动 HTTP 服务暴露分析接口,再用 go tool pprof 抓取并可视化数据。CPU 和内存报告的生成方式略有不同,关键在于采样方式和采集时机。

CPU 分析:抓取运行时热点函数

CPU 分析需持续采样一段时间(默认 30 秒),反映程序在 CPU 上实际花费时间最多的代码路径。前提是你的服务已启用 net/http/pprof

  • 确保主程序中注册了 pprof 路由
    import _ "net/http/pprof",并在某处启动 HTTP 服务,例如:
    go http.ListenAndServe("localhost:6060", nil)
  • 触发业务逻辑(比如发几个请求让程序忙起来),再执行采集:
    go tool pprof http://localhost:6060/debug/pprof/profile
    会自动等待 30 秒采样,完成后进入交互式分析界面
  • 常用命令:
    top10 查看耗时 Top 10 函数
    web 生成火焰图(需安装 graphviz)
    svg > cpu.svg 导出 SVG 火焰图文件

内存分析:区分 allocs 和 inuse

Go 内存报告分两类:allocs(累计分配总量,含已释放)和 inuse_space(当前堆上实际占用的内存)。排查泄漏优先看 inuse

  • 获取当前内存快照:
    go tool pprof http://localhost:6060/debug/pprof/heap → 默认是 inuse_space
    go tool pprof http://localhost:6060/debug/pprof/allocs → 看总分配量
  • 若想观察内存增长趋势,可多次采集后对比:
    先记下初始状态:curl -s "http://localhost:6060/debug/pprof/heap?debug=1" | grep "inuse_objects\|inuse_space"
    执行可疑操作(如反复创建资源),再查一次,看差值
  • 在 pprof 交互中用 toplist YourFuncName 定位具体分配点

离线分析:保存 profile 文件再分析

生产环境通常不允许直接连 pprof 接口,推荐先下载 profile 文件,本地分析更安全可控。

LongShot
LongShot

LongShot 是一款 AI 写作助手,可帮助您生成针对搜索引擎优化的内容博客。

下载

立即学习go语言免费学习笔记(深入)”;

  • 下载 CPU profile:
    curl -o cpu.pprof "http://localhost:6060/debug/pprof/profile?seconds=60"
  • 下载 heap profile:
    curl -o heap.pprof "http://localhost:6060/debug/pprof/heap"
  • 本地分析:
    go tool pprof cpu.pprof
    go tool pprof heap.pprof
  • 注意:分析时最好带上二进制文件,能显示源码行号:
    go tool pprof your-binary cpu.pprof

关键细节提醒

pprof 不是万能的,几个容易踩的坑要提前知道:

  • HTTP 服务地址必须可访问;若程序没开 HTTP 服务,可用 runtime/pprof 手动写入文件,但需自行控制采样时机
  • CPU 分析期间程序会稍慢(因采样开销),但影响有限;内存 profile 是瞬间快照,无持续开销
  • GC 频繁可能掩盖真实内存问题,采集前可调大 GOGC 或手动 runtime.GC() 清理一次再采
  • 火焰图中扁平宽条不等于瓶颈,要看“自耗时”(flat)和“含子调用总耗时”(cum)结合判断

相关文章

数码产品性能查询
数码产品性能查询

该软件包括了市面上所有手机CPU,手机跑分情况,电脑CPU,电脑产品信息等等,方便需要大家查阅数码产品最新情况,了解产品特性,能够进行对比选择最具性价比的商品。

下载

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

相关专题

更多
golang如何定义变量
golang如何定义变量

golang定义变量的方法:1、声明变量并赋予初始值“var age int =值”;2、声明变量但不赋初始值“var age int”;3、使用短变量声明“age :=值”等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

173

2024.02.23

golang有哪些数据转换方法
golang有哪些数据转换方法

golang数据转换方法:1、类型转换操作符;2、类型断言;3、字符串和数字之间的转换;4、JSON序列化和反序列化;5、使用标准库进行数据转换;6、使用第三方库进行数据转换;7、自定义数据转换函数。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

224

2024.02.23

golang常用库有哪些
golang常用库有哪些

golang常用库有:1、标准库;2、字符串处理库;3、网络库;4、加密库;5、压缩库;6、xml和json解析库;7、日期和时间库;8、数据库操作库;9、文件操作库;10、图像处理库。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

335

2024.02.23

golang和python的区别是什么
golang和python的区别是什么

golang和python的区别是:1、golang是一种编译型语言,而python是一种解释型语言;2、golang天生支持并发编程,而python对并发与并行的支持相对较弱等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

206

2024.03.05

golang是免费的吗
golang是免费的吗

golang是免费的。golang是google开发的一种静态强类型、编译型、并发型,并具有垃圾回收功能的开源编程语言,采用bsd开源协议。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

388

2024.05.21

golang结构体相关大全
golang结构体相关大全

本专题整合了golang结构体相关大全,想了解更多内容,请阅读专题下面的文章。

193

2025.06.09

golang相关判断方法
golang相关判断方法

本专题整合了golang相关判断方法,想了解更详细的相关内容,请阅读下面的文章。

184

2025.06.10

golang数组使用方法
golang数组使用方法

本专题整合了golang数组用法,想了解更多的相关内容,请阅读专题下面的文章。

191

2025.06.17

ip地址修改教程大全
ip地址修改教程大全

本专题整合了ip地址修改教程大全,阅读下面的文章自行寻找合适的解决教程。

27

2025.12.26

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Go 教程
Go 教程

共32课时 | 3万人学习

Go语言实战之 GraphQL
Go语言实战之 GraphQL

共10课时 | 0.8万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号