Eclipse Memory Analyzer是一个快速且功能丰富的Java堆分析器,可帮助您查找内存泄漏并减少内存消耗。使用Memory Analyzer分析具有数亿个对象的高效堆转储,快速计算对象的保留大小,查看谁阻止垃圾收集器收集对象,运行报告以自动提取泄漏嫌疑者
官网下载链接
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:
即在OutOfMemoryError后获取一份HPROF二进制Heap Dump文件,在jvm中添加参数:
-XX:+HeapDumpOnOutOfMemoryError
在虚拟机添加参数如下,然后在Ctrl+Break组合键即可获取一份Heap Dump
-XX:+HeapDumpOnCtrlBreak
使用Agent可以在程序执行结束时或受到SIGOUT信号时生成Dump文件
配置在虚拟机的参数如下:
-agentlib:hprof=heap=dump,format=b
jmap可以在cmd里执行,命令如下:
jmap -dump:format=b file=<文件名XX.hprof> <pid>
使用Memory Analyzer Tools的File -> Acquire Heap Dump功能
Histogram是使用最多的一个,可以列出内存中的对象,对象的个数及其大小
具体信息
按包名的形式进行排列
在某一项上右键打开菜单选择list objects ->with incoming refs将列出该类的实例
with outgoing references:这个类引用到了哪些类
with incoming references:这个类被哪些类所引用
快速找出某个实例没被释放的原因,可以右健Path to GC Roots–>exclue all phantom/weak/soft etc. reference
用这个方法可以快速找到某个对象的GC Root,一个存在GC Root的对象是不会被GC回收掉的
自动分析内存内存泄漏的原因,可以直接定位到Class和代码行数
深色区域被怀疑有内存泄漏,具体点开详情来找到类
通过图型列出最大的Object
列出线程的树结构,及线程下面对象占用内存的空间
Percentage:这个对象占所有对象的百分比,前面这几个对象占10%,可以知道它占内存的大部分,需要详细地进行优化这部分对象,需要看一下这些对象能不能被回收以及它为什么没有被回收
with outgoing references:这个类引用了哪些对象
with incoming references:这个类被哪些对象所引用
dominator_tree与Histogram中中这两个值的区别是:
在dominator_tree中,会将具体的对象列出来
详细地展示线程信息
找到最属于自己服务代码中最可疑的堆栈对象后,查询list object --> out comming,查看它里面包括了什么
直接通过dominator_tree,按retained head排序,然后看最大的线程在持有哪些大对象,还可以右键查看线程详细堆栈信息
经常服务直接OOM,所以需要自动触发headdump
OOM时自动触发headdump
-XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=/app/temp/heapdump.hprof
FGC前后做headdump
-XX:+HeapDumpBeforeFullGC -XX:+HeapDumpAfterFullGC -XX:HeapDumpPath=/app/temp/