IT技术博客大学习 共学习 共进步
全部 移动开发 后端 数据库 AI 算法 安全 DevOps 前端 设计 开发者

使用valgrind的callgrind工具进行多线程性能分析

博学无忧 2014-12-08 23:23:54 累计浏览 3,626 次
本机暂存
简介

   valgrind是开源的性能分析利器。 根据它的文档,可以用它来检查内存泄漏等问题,还可以用来生成函数的调用图,就这两个功能就足够有吸引力了。

   本文主要是介绍如何使用valgrind的callgrind工具进行性能分析。

分析过程

使用callgrind工具生成性能分析数据

   命令格式如下:

valgrind --tool=callgrind ./exproxy

   其中 ./exproxy就是我们要分析的程序。执行完毕后,就会在当前目录下生成一个文件。文件名为“callgrind.out.进程号”。如,callgrind.out.31113。注意,对于daemon进程的调试,不要通过kill -9方式停止。

   如果你调试的程序是多线程,你也可以在命令行中加一个参数 -separate-threads=yes。这样就会为每个线程单独生成一个性能分析文件。如下:

valgrind --tool=callgrind --separate-threads=yes ./exproxy

   生成的文件除了callgrind.out.31113外,还会多出一些子线程的文件。文件名如下:

   callgrind.out.31113-01    callgrind.out.31113-02    callgrind.out.31113-03

把callgrind生成的性能数据转换成dot格式数据

   可以使用gprof2dot.py脚本,把callgrind生成的性能分析数据转换成dot格式的数据。方便使用dot把分析数据图形化。

   脚本可以点此下载。脚本使用方式如下:

python gprof2dot.py -f callgrind -n10 -s callgrind.out.31113 > valgrind.dot

使用dot把数据生成图片

   命令格式如下:

dot -Tpng valgrind.dot -o valgrind.png 

生成的图片示例

   callgrind_dot

   通过图形,我们可以很直观的知道那段程序执行慢,并且了解相关调用关系。

同分类推荐文章

  1. 等了十年的 Go 链式管道,终于来了:seq 让你像写 Scala 一样写 Go (2026-06-25 18:38:18)
  2. Go 实验特性详解 (2026-06-21 10:05:27)
  3. amd64 微架构级别对 Go 程序性能提升多少? (2026-06-21 09:38:49)

查看更多 后端 文章 →

建议继续学习

  1. 由浅入深探究mysql索引结构原理、性能分析与优化 (累计阅读 16,523)
  2. Linux如何统计进程的CPU利用率 (累计阅读 16,308)
  3. 如何查找消耗资源较大的SQL (累计阅读 15,211)
  4. Linux Used内存到底哪里去了? (累计阅读 11,867)
  5. 浅析C++多线程内存模型 (累计阅读 8,802)
  6. C++ 多线程编程总结 (累计阅读 8,097)
  7. 并发编程系列之一:锁的意义 (累计阅读 7,569)
  8. WEB性能测试工具推荐 (累计阅读 7,066)
  9. 近期Imgsrc一处内存泄露问题的查找和解决 (累计阅读 6,799)
  10. Linux下CPU的利用率 (累计阅读 6,653)