当前位置: 首页 > news >正文

Golang pprof 分析程序的使用内存和执行时间

一、分析程序执行的内存情况

package mainimport ("os""runtime/pprof"
)func main() {// ... 你的程序逻辑 ...// 将 HeapProfile 写入文件f, err := os.Create("heap.prof")if err != nil {panic(err)}defer f.Close()pprof.WriteHeapProfile(f)
}

然后执行:

# 解析 heap.prof 文件
go tool pprof -alloc_space heap.prof# 在交互式界面中查看数据
(pprof) top

其他的选项还有:

-alloc_space:查看分配空间相关的信息
-inuse_space:查看当前内存使用情况

效果大概是这样的:

二、分析程序执行的CPU使用时间情况

import ("os""runtime/pprof""log"
)func main() {// 创建文件用于保存 CPU profilef, err := os.Create("cpu.prof")if err != nil {log.Fatal(err)}defer f.Close()// 开始 CPU profilingif err := pprof.StartCPUProfile(f); err != nil {log.Fatal(err)}defer pprof.StopCPUProfile()// 其他程序逻辑...
}

然后同理执行:

go tool pprof cpu.prof# 在交互式界面中查看数据
(pprof) top

效果是这样的:

也是可以通过 top 和 list 某个函数步骤去查看具体信息

http://www.lryc.cn/news/310933.html

相关文章:

  • C/C++平方和问题(蓝桥杯)
  • (libusb) usb口自动刷新
  • NLP(一)——概述
  • 智慧公厕:打造智慧城市的环卫明珠
  • [LeetBook]【学习日记】寻找链表相交节点
  • 【Python】OpenCV-使用ResNet50进行图像分类
  • TypeError: `dumps_kwargs` keyword arguments are no longer supported
  • 设计模式学习笔记 - 设计原则 - 3.里氏替换原则,它和多态的区别是什么?
  • java实现图片转pdf,并通过流的方式进行下载(前后端分离)
  • 如何系统的学习Python——Python的基本语法
  • 相机,棱镜和光场
  • 【图像版权】论文阅读:CRMW 图像隐写术+压缩算法
  • 代码随想录算法训练营第31天—贪心算法05 | ● 435. 无重叠区间 ● *763.划分字母区间 ● *56. 合并区间
  • 2024《》
  • 【Web】Java反序列化之从CC3看TemplatesImpl的利用
  • 【Elasticsearch索引】Recovery恢复索引
  • 如何在 Linux 中快速清空文件而不删除它们?
  • SpringBoot 配置文件${variable:default}用法
  • CUDA学习笔记02:测试程序hello world
  • 2023年第十四届蓝桥杯大赛软件类省赛C/C++大学A组真题
  • 项目部署发布
  • MATLAB环境下基于离散小波变换的心电信号伪影去除及PQRST波检测
  • SwiftUI 在 App 中弹出全局消息横幅(下)
  • 2023年06月CCF-GESP编程能力等级认证Scratch图形化编程三级真题解析
  • 升级openssl
  • 软考基础知识2
  • Python基本数据类型介绍
  • 边缘计算网关:连接物理世界与数字世界的桥梁-天拓四方
  • NTP网络校时服务器(GPS北斗卫星校时系统)应用场景
  • Intel 芯片 Mac 如何重新安装系统