`
小滔哥
  • 浏览: 58960 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类

google-perf-tools使用笔记

 
阅读更多
  • 1.Perftools 介绍

    项目地址 http://code.google.com/p/gperftools/

      引用原文里的一段英文介绍

      Perftools is a collection of a high-performance multi-threaded malloc() implementation, plus some pretty nifty performance analysis tools.

      Perftools 是一个高效的多线程 malloc 实现,附加一些很好的性能分析工具。使用这个工具进行分析 cpu profiling memory leak 分析是很不错的。

 

 

  • 2.Perftools 下载、安装

    下载地址 http://code.google.com/p/gperftools/downloads/list ,从这里面选择一个版本,下载后解压,然后进行安装。安装步骤如下

./configure –enable-frame-pointers
Make
Make install

    不出问题的话,上面就可以完成安装了,如有问题,看下 INSTALL,README 文档进行解决。

 

 

  • 3.Perftools使用方法

    使用方法有两种

    第一种 设置 LD_PRELOAD

          假设要分析的执行文件为 run.out

          Export LD_PRELOAD=/usr/local/lib/libprofiler.so:/usr/local/lib/libtcmalloc.so

          其中第一个库是做 cpu profiling 需要的库,第二个是对 memory profiling 需要的库

          然后执行 CPUPROFILE=/tmp/prof.out HEAPCHECK=strict /path/to/run.out

          便会在 /tmp/ 目录下生成 prof.out /tmp/run.out.xxxend.heap. 这样的文件

 

    第二种在编译的时候添加 -lprofiler –ltcmalloc 选项

          例如 gcc –o run.so test.c –lprofiler –ltcmalloc ,这样生成的 run.out 在运行的时候也能得到 profling 的结果文件

          CPUPROFILE=/tmp/prof.out HEAPCHECK=strict /path/to/run.out

          同样会在 /tmp 目录下生成第一种方法那样的两个文件

 

 

  • 4.分析结果

      使用 pprof profiling 的结果文件进行分析

      对 cpu profiling 的结果文件执行下面的命令

      pprof --text ./a.out /tmp/prof.out

      会得到类似下面的输出,从中可以看到各个函数执行时间的比例

Using local file ./a.out.

Using local file /tmp/prof.out.

Removing killpg from all stack traces.

Total: 2255 samples

    1677  74.4%  74.4%     1677  74.4% consumeSomeCPUTime1

     578  25.6% 100.0%     1131  50.2% consumeSomeCPUTime2

       0   0.0% 100.0%     2255 100.0% __libc_start_main

       0   0.0% 100.0%     2255 100.0% main

       0   0.0% 100.0%     2255 100.0% stupidComputing 
 

      每一列的含义如下所示

      1.Number of profiling samples in this function

      2.Percentage of profiling samples in this function

      3.Percentage of profiling samples in the functions printed so far

      4.Number of profiling samples in this function and its callees

      5.Percentage of profiling samples in this function and its callees

      6.Function name

 

      对 memory   profiling 的结果文件执行下面的命令

      pprof --text ./run.out /tmp/run.out.29318._main_-end.heap

      会得到类似下面的输出,给出了 memory leak 产生的函数及所占比例

Total: 0.0 MB

     0.0  66.7%  66.7%      0.0  66.7% b

     0.0  33.3% 100.0%      0.0  33.3% a

     0.0   0.0% 100.0%      0.0 100.0% __libc_start_main

     0.0   0.0% 100.0%      0.0 100.0% main 

      每一列的含义同上面类似,将 leak 的比例函数执行时间的比例即可。

      当然,还可以选择其他的生成方式,例如将--text换成--pdf,--gv等这样的,生成pdf和图片方式。

 

 

    • 5.总结

             Perftools 是个很不错的工具,对无论性能分析,还是对内存进行分析,都能给开发者提供很好的解决问题思路。而且工具是开源的,如果需要加一些什么功能或者修复什么 bug ,也是比较方便的,我们这边有同学就加了一点功能。以后把这个工具用起来,再慢慢谈使用这个工具的一些经验吧。

      分享到:
      评论

      相关推荐

        基于springboot教育资源共享平台源码数据库文档.zip

        基于springboot教育资源共享平台源码数据库文档.zip

        视频笔记linux开发篇

        linux开发篇,配套视频:https://www.bilibili.com/list/474327672?sid=4493702&spm_id_from=333.999.0.0&desc=1

        readera-24-09-08plus2020.apk

        ReadEra 这个阅读应用能够打开下列任何格式的文档: EPUB, PDF, DOC, RTF, TXT, DJVU, FB2, MOBI, 和 CHM. 基本上来说,你可以用它阅读你的设备内存中的任何书籍或者文本文档。 这个应用与划分成章节的文档兼。,有一个书签功能,可以在你阅读的时候,自动保存你的进度。另外,它让你更改页面模式,从几种不同的主题中进行挑选(夜间,白天,棕黑色调,还有控制台)。

        STM32单片机控制舵机旋转

        软件环境:KEIL4 硬件环境:STM32单片机+舵机 控制原理:通过控制输出信号的占空比调节舵机旋转的角度

        基于springboot仓库管理系统源码数据库文档.zip

        基于springboot仓库管理系统源码数据库文档.zip

        酒店管理系统源码C++实现的毕业设计项目源码.zip

        酒店管理系统源码C++实现的毕业设计项目源码.zip,个人大四的毕业设计、经导师指导并认可通过的高分设计项目,评审分98.5分。主要针对计算机相关专业的正在做毕设的学生和需要项目实战练习的学习者,也可作为课程设计、期末大作业。 酒店管理系统源码C++实现的毕业设计项目源码.zip,酒店管理系统源码C++实现的毕业设计项目源码.zip个人大四的毕业设计、经导师指导并认可通过的高分设计项目,评审分98.5分。主要针对计算机相关专业的正在做毕设的学生和需要项目实战练习的学习者,也可作为课程设计、期末大作业。酒店管理系统源码C++实现的毕业设计项目源码.zip酒店管理系统源码C++实现的毕业设计项目源码.zip酒店管理系统源码C++实现的毕业设计项目源码.zip,个人大四的毕业设计、经导师指导并认可通过的高分设计项目,评审分98.5分。主要针对计算机相关专业的正在做毕设的学生和需要项目实战练习的学习者,也可作为课程设计、期末大作业。酒店管理系统源码C++实现的毕业设计项目源码.zip,个人大四的毕业设计、经导师指导并认可通过的高分设计项目,评审分98.5分。主要针对计算机相关专业的正在做毕

        58商铺全新UI试客试用平台网站源码

        58商铺全新UI试客试用平台网站源码

        基于SpringBoot+Vue的轻量级定时任务管理系统.zip

        springboot vue3前后端分离 基于SpringBoot+Vue的轻量级定时任务管理系统.zip

        毕业设计&课设_微博情感分析,用 flask 构建 restful api,含相关算法及数据文件.zip

        该资源内项目源码是个人的课程设计、毕业设计,代码都测试ok,都是运行成功后才上传资源,答辩评审平均分达到96分,放心下载使用! ## 项目备注 1、该资源内项目代码都经过严格测试运行成功才上传的,请放心下载使用! 2、本项目适合计算机相关专业(如计科、人工智能、通信工程、自动化、电子信息等)的在校学生、老师或者企业员工下载学习,也适合小白学习进阶,当然也可作为毕设项目、课程设计、作业、项目初期立项演示等。 3、如果基础还行,也可在此代码基础上进行修改,以实现其他功能,也可用于毕设、课设、作业等。 下载后请首先打开README.md文件(如有),仅供学习参考, 切勿用于商业用途。

        4D毫米波雷达点云数据处理方法研究.caj

        4D毫米波雷达点云数据处理方法研究.caj

        S M 2 2 5 8 X T量产工具

        S M 2 2 5 8 X T 量产工具供大家下载使用

        基于springboot的文物管理系统源码数据库文档.zip

        基于springboot的文物管理系统源码数据库文档.zip

        基于springboot的电影院售票管理系统源码数据库文档.zip

        基于springboot的电影院售票管理系统源码数据库文档.zip

        Javaweb仓库管理系统项目源码.zip

        基于Java web 实现的仓库管理系统源码,适用于初学者了解Java web的开发过程以及仓库管理系统的实现。

        美容美发项目,使用django框架,前后端一体化项目

        美容美发项目,使用django框架,前后端一体化项目

        2023年中国在线票务行业市场规模约为24.99亿元,挖掘市场新机遇

        在线票务:2023年中国在线票务行业市场规模约为24.99亿元,挖掘市场蓝海新机遇 在数字浪潮的席卷下,传统的票务销售模式正经历着前所未有的变革。纸质门票逐渐淡出人们的视野,取而代之的是便捷、高效的数字和移动票务。这一转变不仅为消费者带来了前所未有的购票体验,更为在线票务平台开辟了广阔的发展空间和市场机遇。随着国民经济的持续增长和文体娱乐行业的蓬勃发展,中国在线票务行业正站在时代的风口浪尖,等待着每一位有志之士的加入。那么,这片蓝海市场究竟蕴藏着怎样的潜力?又该如何把握机遇,实现突破?让我们一同探索。 市场概况: 近年来,中国在线票务行业市场规模持续扩大,展现出强劲的增长势头。据QYResearch数据显示,2023年中国在线票务行业市场规模约为24.99亿元,尽管受到宏观经济的影响,市场规模增速放缓,但整体趋势依然向好。这一增长主要得益于国民人均收入的不断提高、电影及演出行业的快速发展以及政府政策的支持。例如,2023年财政部、国家电影局发布的《关于阶段性免征国家电影事业发展专项资金政策的公告》,为电影行业注入了强劲动力,进而推动了在线票务市场规模的扩大。 技术创新与趋势: 技术进步

        基于SpringBoot的养老院管理系统源码数据库文档.zip

        基于SpringBoot的养老院管理系统源码数据库文档.zip

        毕业设计&课设_含构建设置及相关操作,基于特定技术,具体功能未详细说明.zip

        该资源内项目源码是个人的课程设计、毕业设计,代码都测试ok,都是运行成功后才上传资源,答辩评审平均分达到96分,放心下载使用! ## 项目备注 1、该资源内项目代码都经过严格测试运行成功才上传的,请放心下载使用! 2、本项目适合计算机相关专业(如计科、人工智能、通信工程、自动化、电子信息等)的在校学生、老师或者企业员工下载学习,也适合小白学习进阶,当然也可作为毕设项目、课程设计、作业、项目初期立项演示等。 3、如果基础还行,也可在此代码基础上进行修改,以实现其他功能,也可用于毕设、课设、作业等。 下载后请首先打开README.md文件(如有),仅供学习参考, 切勿用于商业用途。

        Go语言入门指南:基础语法、并发编程详解

        内容概要:本文档是一份详细的Go语言教程,从基础概念介绍到高级主题均有覆盖。主要内容包括Go语言的基础语法、数据类型、控制结构、函数、结构体、接口和并发编程等方面。通过具体示例介绍了如何使用Go语言进行开发。 适合人群:初学者和有一定经验的程序员都可以从这篇教程中受益,特别是那些想要快速掌握Go语言并应用于实际项目的开发者。 使用场景及目标:适用于初学者系统学习Go语言的基础知识和常用功能;也可以作为已有开发经验者的参考资料,帮助他们解决具体的编程问题,提高开发效率。 其他说明:本教程不仅包含了Go语言的基本知识点,还重点讲解了其独特的并发编程模型。读者在学习过程中应该注重理论与实践相结合,通过实际编写代码来加深理解和记忆。

        基于springboot计算机基础网上考试系统源码数据库文档.zip

        基于springboot计算机基础网上考试系统源码数据库文档.zip

      Global site tag (gtag.js) - Google Analytics