Memory Analyzer排查内存溢出

一、jmap 的使用

首先,需要使用 jmap 工具生成 dump 文件。

jmap是java自带的工具

1. 查看整个JVM内存状态 

jmap -heap [pid]

pid 为 java 进程号,可使用jps 或者 linux 命令行查看,

 

通过 ps -ef | grep java  得到如上线程将某线程终止时用 

kill -9 XXXXX     XXXXX为上述查出的序号  如: 19979线程终止为: kill -9 4834 

Memory Analyzer排查内存溢出

2. 查看JVM堆中对象详细占用情况
jmap -histo [pid]


3. 导出整个JVM 中内存信息,可以利用其它工具打开dump文件分析,例如jdk自带的visualvm工具

jmap -dump:file=文件名.dump [pid]

Memory Analyzer排查内存溢出

 

二、使用 Memory Analyzer 分析 dump 文件

生成Hrof 文件

Memory Analyzer排查内存溢出

把studio生成的hrof文件导出使用hprof-conv.exe转换 ,注意这里不转换Memory Analyzer无法打开
\sdk\platform-tools 路径下面找到 hprof-conv.exe

Memory Analyzer排查内存溢出

转换后的文件我取名memory3333
使用Memory Analyzer打开转换后的文件

找到下载的Memory Analyzer

Memory Analyzer排查内存溢出
*
打开转换后的hrof文件

Memory Analyzer排查内存溢出

打开后

Memory Analyzer排查内存溢出

开始排查

点击histogram ,在Class Name这一栏输入你要过滤的类名,回车

Memory Analyzer排查内存溢出

搜索类名的结果 ,发现这个类有13个对象 ,正常情况找个类只有一个对象,所以这个类泄漏了

Memory Analyzer排查内存溢出

继续查找是谁使用了这个类 ,一直持有这个类的对象,导致无法释放
第一步: 排除需引用

Memory Analyzer排查内存溢出

第二步:找到被谁持有

Memory Analyzer排查内存溢出

结果

Memory Analyzer排查内存溢出

找到泄漏原因

Memory Analyzer排查内存溢出

Memory Analyzer排查内存溢出


结果,发现是CallBackManager类中的sCallBack持有了MemoryLeakActivity的引用
既然找到了原因 ,自己就去查看代码吧


根据包名查看

打开histogram ,根据图片步骤选择 Group by package

Memory Analyzer排查内存溢出

找到自己app包名 ,根据业务逻辑排查 ,大多数情况下一个只有一个实例 ,如果有多的怀疑是不是泄漏

Memory Analyzer排查内存溢出

Memory Analyzer排查内存溢出

使用查看Memory Analyzer线程

Memory Analyzer排查内存溢出

 

使用Memory Analyzer数据库方式搜索类名,查看改类是否存在异常

Memory Analyzer排查内存溢出

 

dominator_tree查看内存占比 ,排斥占用内存多的原因 ,把占用内存多的释放掉

Memory Analyzer排查内存溢出

 

其它

Memory Analyzer排查内存溢出