前言
在平时开发、测试过程中、甚至是生产环境中,有时会遇到OutOfMemoryError,Java堆溢出了,这表明程序有严重的问题。我们需要找造成OutOfMemoryError原因。一般有两种情况:
1、内存泄露,对象已经死了,无法通过垃圾收集器进行自动回收,通过找出泄露的代码位置和原因,才好确定解决方案;
2、内存溢出,内存中的对象都还必须存活着,这说明Java堆分配空间不足,检查堆设置大小(-Xmx与-Xms),检查代码是否存在对象生命周期太长、持有状态时间过长的情况。
以上是处理Java堆问题的思路,具体是怎么进行分析,这里介绍的是使用Eclipse Memory Analyzer tool(MAT)工具分析的过程。
Eclipse Memory Analyzer的安装及简单使用介绍
MAT下载链接解压即可使用(点击 MemoryAnalyzer.exe 打开),也可以自己去官网下。
获取Heap dump文件
有三种方式:
1、设置JVM参数,-XX:+HeapDumpOnOutOfMemoryError,在内存溢出的时候就会生成Heap dump文件
2、使用jmap。(windows可以通过任务管理器查看pid)
Java5:jmap -heap:format=b ;
Java6:jmap -dump:format=b,file=HeapDump.bin
3、在本机运行java程序的时候,直接通过Memory Analyzer生成Heap dump文件。
在这里我只介绍第三种方式:
File—acquire Heap Dump,如图所示双击红色方框部分
进入主页,如下图:
功能介绍
1. Histogram:可以列出内存中的对象,对象的个数以及大小。
2. Dominator Tree:可以列出那个线程,以及线程下面的那些对象占用的空间。
3.Top consumers:通过图形列出最大的object。
4.Leak Suspects:通过MA自动分析泄漏的原因。
在后面的样例中,我会把这四个功能一个个讲一遍。
概