问题排查-jmap和MAT工具

2023-04-27,,

jmap常用命令

1、heap
命令:jmap -heap pid
描述:显示Java堆详细信息

2、histo[:live]
命令:jmap -histo:live pid
描述:显示堆中对象的统计信息

3、dump:<dump-options>
命令:jmap -dump:format=b,file=heapdump.phrof pid
描述:生成堆转储快照dump文件。

以hprof二进制格式转储Java堆到指定filename的文件中。live子选项是可选的。如果指定了live子选项,堆中只有活动的对象会被转储。

利用MAT分析dump文件

打开dump如图:

重要功能

1、Histogram

Histogram,可列出每一个类的实例数,支持正则表达式查找,也可以计算出该类所有对象的retained size。

Shallow Heap就是对象本身占用内存的大小,不包含其引用的对象内存,实际分析中作用不大。

Retained Heap值的计算方式是将RSet(当该对象被回收时那些将被GC回收的对象集合)中的所有对象大小叠加。或者说,因为X被释放,导致其它所有被释放对象(包括被递归释放的)所占的heap大小。

1、选择一个Class,右键选择List objects > with incoming references,在新页面会显示通过这个class创建的对象信息。
2、然后再选择一个对象,右键选择Path to GC Roots > ****,通常在排查内存泄漏的时候,我们会选择exclude all phantom/weak/soft etc.references,意思是查看排除虚引用/弱引用/软引用等的引用链,也就是强引用链。

2、Leak Suspects

Leak Suspects 界面提示可能存在内存的泄露。
比方说大对象:

通过Details可以查看具体问题的详情!

《问题排查-jmap和MAT工具.doc》

下载本文的Word格式文档,以方便收藏与打印。