MAT 全称 Eclipse Memory Analysis Tools 是一个分析 Java堆数据的专业工具,可以计算出内存中对象的实例数量、占用空间大小、引用关系等,看看是谁阻止了垃圾收集器的回收工作,从而定位内存泄漏的原因。
什么时候会用到MAT?
a) OutOfMemoryError的时候,触发full gc,但空间却回收不了,引发内存泄露
b)java服务器系统异常,比如load飙高,io异常,或者线程死锁等,都可能通过分析堆中的内存对象来定位原因
如何安装:
eclipse插件安装,地址:http://download.eclipse.org/mat/1.0/update-site/
分析文件生成方式:
a)自动生成,jvm启动参数里添加下面配置,当发生OutOfMemoryError时,虚拟机会自动dump内存快照
-XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=$LOG_DIR/java.hprof"
b)手动生成,通过执行jdk自带命令
jmap -dump:format=b,file=heap.bin <pid>
接下就可以用 MAT打开转换后的 hprof文件
打开后的首页,里面是一些堆的基本概要信息,比如空间大小、类的数量、对象实例数量、类加载器等等
Atcion里面提供了多种分析维度:
- Histogram可以列出内存中的对象,对象的个数以及大小。
- Dominator Tree可以列出那个线程,以及线程下面的那些对象占用的空间。
- Top consumers通过图形列出最大的object。
- Leak Suspects通过MA自动分析泄漏的原因。