用法
首先需要把tcmalloc链接到我们需要分析的程序中, 当然我们也可以动态load 这个lib,但是为了简单起见,还是推荐大家链接这个lib到自己的程序中。
链接之后,我们接下来的任务就是得到内存分析的dump文件,我们有两种方法:
1 静态dump方法:
直接定义一个环境变量HEAPPROFILE 来指定dump profile文件的位置,如:/tmp/testlog,它将会在/tmp/目录下生成很多类似/tmp/testlog0003heap文件名的文件
env HEAPPROFILE="/tmp/testlog" /test/testprog
2 动态dump方法:
我们可以调用Google Heap Profiler的API来控制什么时候dump出内存的profiler文件,这样更加灵活,为此,我们必须包含heap-profilerh这个头文件。
HeapProfilerStart() 用来开始内存分析
HeapProfilerStop() 用来终止内存分析
这样就只会在开始和结束之间产生dump profiler文件。
选项
HEAP_PROFILE_ALLOCATION_INTERVAL
程序内存每增长这一数值之后就dump 一次内存,默认是1G (1073741824)
HEAP_PROFILE_INUSE_INTERVAL
程序如果一次性分配内存超过这个数值dump 默认是100K, 待验证
查看内存dump文件
这么dump文件生成之后,我们接下来就可以查看内存的分布情况,如:
pprof --pdf /test/testProg /tmp/testlog0001heap
就是以pdf的形式来显示这个dump文件,当然我们也可以使用其他的格式来显示。
--text Generate text report
--callgrind Generate callgrind format to stdout
--gv Generate Postscript and display
--evince Generate PDF and display
--web Generate SVG and display
--list= Generate source listing of matching routines
--disasm= Generate disassembly of matching routines
--symbols Print demangled symbol names found at given addresses
--dot Generate DOT file to stdout
--ps Generate Postcript to stdout
--pdf Generate PDF to stdout
--svg Generate SVG to stdout
--gif Generate GIF to stdout
--raw Generate symbolized pprof data (useful with remote fetch)
这就是所有可支持的格式。
注:如果pprof 运行出错,请检查时候已经正确安装,如果出现sh: dot: command not found 这个错误,就是需要安装yum install graphviz -y
我们也可以专门focus在一些包含某些关键字的路径上,也可以忽略相关的路径
--focus
--ignore
pprof --pdf --focus=CData /test/testProg /tmp/testlog0001heap
比较dump文件
为了知道在某一段时间内的内存分布情况,或者需要了解某段时间内有没有内存泄露,我们就需要用到diff我们的dump文件
例如:pprof --pdf --base /tmp/testlog0001heap /test/testProg /tmp/testlog0101heap
比较了第一个dump文件与第101个文件的差异,而且结果以pdf的形式显示。
以上就是关于如何抓取heap profile全部的内容,包括:如何抓取heap profile、、等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)