gperftools 使用经验总结
先看了网上的一些资料,但都不太适合我。还是看了详细的资料才学会怎么用。
按照 http://www.cnblogs.com/persistentsnail/p/3294843.html,yum安装gperftools-devel 和 libunwind
安装gperftools-devel的时候,同时就安装了 gperftools。如何使用,主要参考了 https://wiki.geany.org/howtos/profiling/gperftools,才入的门,回头再看第一个链接,很多地方就能看懂了。
对第二个链接,我的libprofile.so是装到/usr/lib64下的,必须要执行:
LD_PRELOAD=/usr/lib64/libprofiler.so CPUPROFILE=/tmp/geany.prof geany, 忽略 LD_PRELOAD是不行的。(有的参考资料不需要这个,这有待将来验证)
看分析结果:
pprof --web /usr/bin/geany /tmp/geany.prof
里面同时提到可以不从一开始就做性能分析,
LD_PRELOAD=/usr/lib64/libprofiler.so CPUPROFILE=/tmp/geany.prof CPUPROFILESIGNAL=12 geany
想要做分析的时候,发送信号: killall -12 geany
想停止分析,同样发信号: killall -12 geany
最后看分析结果: pprof --web /usr/local/bin/geany /tmp/geany.prof.0
注意最后有个0。
本来带打算对自己的模块:加入 http://blog.csdn.net/zougangx/article/details/8836749 提到的方法,对特定的程序块做分析,因为要尽快提交一版,先搁置这个实践。但是把其中的关键内容拷贝在下面:
2.设置要分析的程序块
注:CPUProfile为生成的结果数据文件的文件名
3.编译和运行
./test
4.将运行结果CPUProfile转化成pdf格式的文件
二.使用过程中可能出现的问题:
1.运行时出现:No nodes to print
程序逻辑使用CPU次数太少,无法分析
2.程序core dump
循环次数过多(原因不确定)
3.运行进出现:SIGPROF handler is already in use
使用了其它的性能分析工具如:gprof等,造成冲突
总结一下,最全,也比较有价值的文档是 http://www.cnblogs.com/lenolix/archive/2010/12/13/1904868.html, 但它不太适合初学者。
可以通过功能扩展可以实现在运行中间阶段或通过http协议远程控制profiler信息的功能。gperftools-httpd项目就已经初步完成了这个功能,我们可以体验一下。
从http://code.google.com/p/gperftools-httpd/下载gperftools-httpd安装。
说是可以编译,但实际从google根本下不到这个,只能从github上下载,虽然有多个gperftools-httpd,点击后发现,都是同一家公司放上去的。编译时,说 -lstacktrace失败。到gperftools源码中看,对.o链接,让其生成libstacktrace.so,提示错误。于是,对gperftools编译过程做记录, make|tee make.out,然后分析make.out和Makefile.am,对stacktrace.so涉及到的3个文件,分别单独编译。
g++ -DHAVE_CONFIG_H -I. -I./src -I./src -DNO_TCMALLOC_SAMPLES -pthread -DNDEBUG -Wall -Wwrite-strings -Woverloaded-virtual -Wno-sign-compare -fno-builtin-malloc -fno-builtin-free -fno-builtin-realloc -fno-builtin-calloc -fno-builtin-cfree -fno-builtin-memalign -fno-builtin-posix_memalign -fno-builtin-valloc -fno-builtin-pvalloc -DNO_FRAME_POINTER -g -O2 -MD -MP -c src/base/vdso_support.cc -fPIC -o ../vdso_support.o
..., 把3个.o移到某个目录中<dir> 最后,g++ <dir>.o -shared -o libstacktrace.so
为了编译不出问题,还需要对gperftools-httpd.h做修改,加上extern "C" ...
extern "C" {
extern void ghttpd(void);
}
同时介绍的Intel公司的vtune,带图形界面,很好用,不过需要license。
一些例子程序可以不用自己编了,http://bitjoy.net/2017/02/07/gperftools-tutorial/提到的git上的代码 https://github.com/01joy/TestGperftools,可以拿过来验证一把。
gperftools 使用经验总结的更多相关文章
- Google performance Tools (gperftools) 使用心得
Google performance Tools (gperftools) 使用心得 gperftools是google开发的一款非常实用的工具集,主要包括:性能优异的malloc free内存分配器 ...
- MyEclipse10--的使用经验
MyEclipse10--的使用经验总结 ------------------ 1.MyEclipse中的验证validation----->>用MyEclipse做ExtJs项目研发的时 ...
- XCode的个人使用经验
Xcode是强大的IDE(但个人觉得不如Visual Studio做得好),其强大功能无需本人再赘述,本文也不是一篇“快捷键列表”,因为XCode上的快捷键极其多,而且还有不少是需要同时按下四个按键的 ...
- Flask-admin使用经验技巧总结
笔者是看狗书入门的flask,狗书上对于flask-admin这个扩展并没有进行讲解,最近因为项目需要,学习使用flask-admin,瞬间体会到了flask开发的快速.扩展的强大 Flask-adm ...
- Unity3D使用经验总结 缺点篇
不论是从官方手册,还是各种第三方教程,几乎涉及到的,都是讲如何使用U3D,以及U3D的优点. 虽然我是用的一个让步语气,但请不要否认U3D的这些优点,它们的确存在. 但对于一个引擎的特性来说,优点与缺 ...
- Unity3D使用经验总结 优点篇
09年还在和其它小伙伴开发引擎的时候,Unity3D就初露头角. 当时就对这种基于组件式的设计结构很不理解. 觉得拆分过于细致,同时影响效率. 而时至今日,UNITY3D已经成为了众多团队的首选3D引 ...
- 控件使用经验-MVP模式+控件封装
项目背景 几年前参与了一个面向学校的人事管理软件的开发,基于WinForm平台.今天主要想谈一谈其中关于控件的使用经验.这个项目我们大量使用了第三方控件.由于这个产品的生命周期很长,我们在设计时要考虑 ...
- 走进异步世界-犯傻也值得分享:ConfigureAwait(false)使用经验分享
在上周解决“博客程序异步化改造之后遭遇的性能问题”的过程中,我们干了一件自以为很有成就感的事——在表现层(MVC与WebForms)将所有使用await的地方都加上了ConfigureAwait(fa ...
- Fastreport使用经验(转)在Delphi程序中访问报表对象
Fastreport使用经验(转) 在Delphi程序中访问报表对象 最基本的方法就是frxReport1.FindObject. 然后把返回的对象强制转换成它的类型,当然,在报表中必须真的有这么个东 ...
随机推荐
- :eq
匹配一个给定索引值的元素?只要在html页面每个元素都有索引值,相同的元素按html位置顺序从0开始往下排.给定索引值:给定一个html某个区域的元素的索引值,也是从0开始 不给区域就是从html从d ...
- hdu4300 Clairewd’s message【next数组应用】
Clairewd’s message Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Other ...
- 多线程 ForkJoinPool
阅读目录 使用 背景:ForkJoinPool的优势在于,可以充分利用多cpu,多核cpu的优势,把一个任务拆分成多个“小任务”,把多个“小任务”放到多个处理器核心上并行执行:当多个“小任务”执行完成 ...
- MySql数据库笔试题总结
数据库面试题94577265 1,设有关系EMP(ENO,ENAME,SALARY,DNO),其中各属性的含义依次为职工号.姓名.工资和所在部门号,以及关系DEPT(DNO,DNAME,MANAGER ...
- git 新建工程
之前的一篇文章 https://www.cnblogs.com/wjw-blog/p/7189730.html,按照流程能搭建好git仓库,有时候会有一些小问题. 按照这个流程:-在github 上新 ...
- 优化网站设计(十):最小化JAVASCRIPT和CSS
前言 网站设计的优化是一个很大的话题,有一些通用的原则,也有针对不同开发平台的一些建议.这方面的研究一直没有停止过,我在不同的场合也分享过这样的话题. 作为通用的原则,雅虎的工程师团队曾经给出过35个 ...
- day14: 生成器进阶
1,复习,迭代器:双下方法很少直接调用,一般都是通过其他语法触发的:迭代器一定可迭代,可迭代的通过调用iter()方法皆可以得到一个迭代器. 迭代器很方便使用,所有的数据只可以取一次,节省内存空间.生 ...
- 查找->静态查找表->折半查找(有序表)
文字描述 以有序表表示静态查找表时,可用折半查找算法查找指定元素. 折半查找过程是以处于区间中间位置记录的关键字和给定值比较,若相等,则查找成功,若不等,则缩小范围,直至新的区间中间位置记录的关键字等 ...
- 文件批量scp分发脚本
#!/bin/bash SERVERS="172.17.xx.y 172.17.pp.mm" PASSWORD=机器登录密码 auto_ssh_copy_file() { expe ...
- NOIP观光公交
#include<iostream> #include<cstdio> #include<cstdlib> #include<cstring> #inc ...