问题排查-jmap和MAT工具

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了问题排查-jmap和MAT工具相关的知识,希望对你有一定的参考价值。

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工具的主要内容,如果未能解决你的问题,请参考以下文章

Java线上故障排查

JAVA线上故障排查全套路

线上故障排查全套路,运维小哥可自查~

Java应用线上问题排查的常用工具和方法

使用jdk常用工具排查故障流程

线上故障排查全套路盘点,运维一片就够