问题排查-jmap和MAT工具

jmap常用命令

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

问题排查-jmap和MAT工具
问题排查-jmap和MAT工具

2、histo[:live]
命令:jmap -histo:live pid
描述:显示堆中对象的统计信息
问题排查-jmap和MAT工具

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

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

问题排查-jmap和MAT工具

利用MAT分析dump文件

打开dump如图:

问题排查-jmap和MAT工具

重要功能

1、Histogram

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

问题排查-jmap和MAT工具

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

问题排查-jmap和MAT工具
Leak Suspects 界面提示可能存在内存的泄露。
比方说大对象:
问题排查-jmap和MAT工具

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

猜你喜欢

转载自blog.51cto.com/janephp/2432551
今日推荐