调优工具MAT内存分析工具

Posted sysu_lluozh

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了调优工具MAT内存分析工具相关的知识,希望对你有一定的参考价值。

Eclipse Memory Analyzer是一个快速且功能丰富的Java堆分析器,可帮助您查找内存泄漏并减少内存消耗。使用Memory Analyzer分析具有数亿个对象的高效堆转储,快速计算对象的保留大小,查看谁阻止垃圾收集器收集对象,运行报告以自动提取泄漏嫌疑者

一、下载地址

官网下载链接

二、Heap Dump

Heap Dump,也叫堆转储文件,是java进程在某个时间内的快照
它在触发快照的时候保存了很多信息:java对象和类信息。通常在写Heap Dump文件前会触发一次Full GC

Heap Dump信息:
Typical information which can be found in heap dumps (once more - depending on the heap dump type) is:

  • All Objects
    Class, fields, primitive values and references
  • All Classes
    Classloader, name, super class, static fields
  • Garbage Collection Roots
    Objects defined to be reachable by the JVM
  • Thread Stacks and Local Variables
    The call-stacks of threads at the moment of the snapshot, and per-frame information about local objects

怎样获取Dump

通过OOM获取

即在OutOfMemoryError后获取一份HPROF二进制Heap Dump文件,在jvm中添加参数:

-XX:+HeapDumpOnOutOfMemoryError

主动获取

在虚拟机添加参数如下,然后在Ctrl+Break组合键即可获取一份Heap Dump

-XX:+HeapDumpOnCtrlBreak

使用HPROF agent

使用Agent可以在程序执行结束时或受到SIGOUT信号时生成Dump文件
配置在虚拟机的参数如下:

-agentlib:hprof=heap=dump,format=b

jmap获取

jmap可以在cmd里执行,命令如下:

jmap -dump:format=b file=<文件名XX.hprof> <pid>

使用JConsole

Acquire Heap Dump

使用Memory Analyzer Tools的File -> Acquire Heap Dump功能

三、MAT用来做什么

  • 找出内存泄漏的原因
  • 找出重复引用的类和jar
  • 分析集合的使用
  • 分析类加载器

四、MAT使用介绍

4.1 Histogram直方图

Histogram是使用最多的一个,可以列出内存中的对象,对象的个数及其大小

4.1.1 具体信息

具体信息

  1. Class Name : 类名称,java类名
  2. Objects : 类的对象的数量,这个对象被创建了多少个
  3. Shallow Heap :一个对象内存的消耗大小,不包含对其他对象的引用
  4. Retained Heap :是shallow Heap的总和,也就是该对象被GC之后所能回收到内存的总和

4.1.2 Group by packages查看

按包名的形式进行排列

4.1.3 查看GC Roots

  • 将列出该类的实例

在某一项上右键打开菜单选择list objects ->with incoming refs将列出该类的实例

with outgoing references:这个类引用到了哪些类
with incoming references:这个类被哪些类所引用

  • 找到GC Roots

快速找出某个实例没被释放的原因,可以右健Path to GC Roots–>exclue all phantom/weak/soft etc. reference

用这个方法可以快速找到某个对象的GC Root,一个存在GC Root的对象是不会被GC回收掉的

4.2 Leak Suspects

自动分析内存内存泄漏的原因,可以直接定位到Class和代码行数

深色区域被怀疑有内存泄漏,具体点开详情来找到类

4.3 Top Comsumers

通过图型列出最大的Object

4.4 Dominator Tree

列出线程的树结构,及线程下面对象占用内存的空间

Percentage:这个对象占所有对象的百分比,前面这几个对象占10%,可以知道它占内存的大部分,需要详细地进行优化这部分对象,需要看一下这些对象能不能被回收以及它为什么没有被回收
with outgoing references:这个类引用了哪些对象
with incoming references:这个类被哪些对象所引用

dominator_tree与Histogram中中这两个值的区别是:

  • dominator_tree基于实例的角度
  • historgram基于类的角度

在dominator_tree中,会将具体的对象列出来

4.5 thread_overview

详细地展示线程信息

五、分析套路

方法一

  1. 通过thread_overview,按retained head排序,展开线程,从调用栈中找到当前服务的代码
  2. 通过histogram,选择group by package,按retained head排序,找到当前服务的代码

找到最属于自己服务代码中最可疑的堆栈对象后,查询list object --> out comming,查看它里面包括了什么

方法二

直接通过dominator_tree,按retained head排序,然后看最大的线程在持有哪些大对象,还可以右键查看线程详细堆栈信息

六、dump文件

经常服务直接OOM,所以需要自动触发headdump

OOM时自动触发headdump

-XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=/app/temp/heapdump.hprof

FGC前后做headdump

-XX:+HeapDumpBeforeFullGC -XX:+HeapDumpAfterFullGC -XX:HeapDumpPath=/app/temp/

以上是关于调优工具MAT内存分析工具的主要内容,如果未能解决你的问题,请参考以下文章

JVM常用性能分析工具

性能优化工具-MAT的使用

jvm性能监控与GC调优

Java 性能分析工具-MAT

Eclipse MAT内存分析工具(Memory Analyzer Tool)

内存分析工具之独立版MAT使用