gperftools 使用经验总结
2017-09-27 15:45 tangxiaosheng 阅读(5184) 评论(0) 编辑 收藏 举报先看了网上的一些资料,但都不太适合我。还是看了详细的资料才学会怎么用。
按照 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,可以拿过来验证一把。