使用Eclipse Memory Analyzer分析Tomcat内存溢出

前言

在平时开发、测试过程当中、甚至是生产环境中,有时会遇到OutOfMemoryError,Java堆溢出了,这代表程序有严重的问题。咱们须要找形成OutOfMemoryError缘由。通常有两种状况:php

一、内存泄露,对象已经死了,没法经过垃圾收集器进行自动回收,经过找出泄露的代码位置和缘由,才好肯定解决方案;
二、内存溢出,内存中的对象都还必须存活着,这说明Java堆分配空间不足,检查堆设置大小(-Xmx与-Xms),检查代码是否存在对象生命周期太长、持有状态时间过长的状况。
以上是处理Java堆问题的思路,具体是怎么进行分析,这里介绍的是使用Eclipse Memory Analyzer tool(MAT)工具分析的过程。
 

1.MAT安装与介绍
     下载地址:http://www.eclipse.org/mat/downloads.php。
或  在 eclipse ->install new software -> http://download.eclipse.org/mat/1.6/update-site/ 进行安装

2.配置JVM 
     经过jvm参数--XX:-HeapDumpOnOutOfMemoryError可让JVM在出现内存溢出是Dump出当前的内存转储快照;
  个人配置是:-Xms20m -Xmx20m -XX:+HeapDumpOnOutOfMemoryError
附加:动态看见eclipse运行内存
 
 
3.编写测试代码
public class Test {
	static class OOMObject {
		
	}
	public static void main(String[] args) {
		List<OOMObject> list = new ArrayList<OOMObject>();
		while(true){
			list.add(new OOMObject());
		}
	}
}

运行结果以下java

 

java.lang.OutOfMemoryError: Java heap space
Dumping heap to java_pid2277.hprof ...
Heap dump file created [27929324 bytes in 0.137 secs]
Exception in thread "main" java.lang.OutOfMemoryError: Java heap space
	at java.util.Arrays.copyOf(Arrays.java:3210)
	at java.util.Arrays.copyOf(Arrays.java:3181)
	at java.util.ArrayList.grow(ArrayList.java:261)
	at java.util.ArrayList.ensureExplicitCapacity(ArrayList.java:235)
	at java.util.ArrayList.ensureCapacityInternal(ArrayList.java:227)
	at java.util.ArrayList.add(ArrayList.java:458)
	at com.b2b.console.Test.main(Test.java:13)

 

刷新项目target目录eclipse

双击文件打开:jvm

 
     
     从上图能够看到它的大部分功能。
     1. Histogram能够列出内存中的对象,对象的个数以及大小。
     2. Dominator Tree能够列出那个线程,以及线程下面的那些对象占用的空间。
     3.Top consumers经过图形列出最大的object。
     4.Leak Suspects经过MA自动分析泄漏的缘由。
     
     Histogram以下图:
     Objects:类的对象的数量。
     Shallow size:就是对象自己占用内存的大小,不包含对其余对象的引用,也就是对象头加成员变量(不是成员变量的值)的总和。
     Retained size:是该对象本身的shallow size,加上从该对象能直接或间接访问到对象的shallow size之和。换句话说,retained size是该对象被GC以后所能回收到内存的总和。



 
 
可见,类Test中OOMObject内存溢出.
 
 
以上是经过MAT分析Tomcat应用程序,找到内存泄露的缘由。

 参考文章: http://blog.csdn.net/xb151652000/article/details/8056792工具

相关文章
相关标签/搜索