gperftool 检测内存泄漏

实战

1、程序编译带tcmolloc
2、启动程序

env HEAPPROFILE="/tmp/perf/test_server.perf" HEAP_PROFILE_ALLOCATION_INTERVAL=102400000 HEAPCHECK=strict  test_server

HEAP_PROFILE_ALLOCATION_INTERVAL累计分配内存多少以后进行dump perf文件

HEAP_PROFILE_TIME_INTERVAL 内存
3、使用pperf分析

./pprof test_server test_server.pef --inuse_objects --lines --heapcheck  --edgefraction=1e-10 --nodefraction=1e-10  --pdf > test_server.pdf

用法

首先需要把tcmalloc链接到我们需要分析的程序中, 当然我们也可以动态load 这个lib,但是为了简单起见,还是推荐大家链接这个lib到自己的程序中。

链接之后,我们接下来的任务就是得到内存分析的dump文件,我们有两种方法:

 1.    静态dump方法:

     直接定义一个环境变量HEAPPROFILE 来指定dump profile文件的位置,如:/tmp/test.log,它将会在/tmp/目录下生成很多类似/tmp/test.log.0003.heap文件名的文件

     env HEAPPROFILE="/tmp/test.log" /test/testprog

 2.    动态dump方法:

我们可以调用Google Heap Profiler的API来控制什么时候dump出内存的profiler文件,这样更加灵活,为此,我们必须包含heap-profiler.h这个头文件。

HeapProfilerStart() 用来开始内存分析

HeapProfilerStop(). 用来终止内存分析

这样就只会在开始和结束之间产生dump profiler文件。

选项

//新增有多少正在使用内存写一次文件(正在使用的内存是指未释放的内存,单位,字节,默认100M)
export HEAP_PROFILE_INUSE_INTERVAL=1048570

//新增多少申请内存写一次文件(是指申请的总内存,包括已经释放的,单位,字节,默认1G)
export HEAP_PROFILE_ALLOCATION_INTERVAL=1073700

查看内存dump文件

这么dump文件生成之后,我们接下来就可以查看内存的分布情况,如:

pprof --pdf /test/testProg /tmp/test.log.0001.heap

就是以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/test.log.0001.heap

比较dump文件

为了知道在某一段时间内的内存分布情况,或者需要了解某段时间内有没有内存泄露,我们就需要用到diff我们的dump文件

例如:pprof --pdf --base /tmp/test.log.0001.heap /test/testProg /tmp/test.log.0101.heap

比较了第一个dump文件与第101个文件的差异,而且结果以pdf的形式显示

  • 2
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值