利用内存分析工具(Memory Analyzer Tool,MAT)分析java项目内存泄露

前言

在平时开发、测试过程中、甚至是生产环境中,有时会遇到OutOfMemoryError,Java堆溢出了,这表明程序有严重的问题。我们需要找造成OutOfMemoryError原因。一般有两种情况:

1、内存泄露,对象已经死了,无法通过垃圾收集器进行自动回收,通过找出泄露的代码位置和原因,才好确定解决方案;
2、内存溢出,内存中的对象都还必须存活着,这说明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运行内存

利用内存分析工具(Memory Analyzer Tool,MAT)分析java项目内存泄露_第1张图片

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());
        }
    }
}

利用内存分析工具(Memory Analyzer Tool,MAT)分析java项目内存泄露_第2张图片
运行结果如下
利用内存分析工具(Memory Analyzer Tool,MAT)分析java项目内存泄露_第3张图片

刷新项目target目录
利用内存分析工具(Memory Analyzer Tool,MAT)分析java项目内存泄露_第4张图片
打开java_pid1212.hprof

直接Finish
在这里插入图片描述

利用内存分析工具(Memory Analyzer Tool,MAT)分析java项目内存泄露_第5张图片

从上图可以看到它的大部分功能。
1. Histogram可以列出内存中的对象,对象的个数以及大小。
2. Dominator Tree可以列出那个线程,以及线程下面的那些对象占用的空间。
3.Top consumers通过图形列出最大的object。
4.Leak Suspects通过MAT自动分析泄漏的原因。

 Histogram如下图:
 Objects:类的对象的数量。
 Shallow size:就是对象本身占用内存的大小,不包含对其他对象的引用,也就是对象头加成员变量(不是成员变量的值)的总和。
 Retained size:是该对象自己的shallow size,加上从该对象能直接或间接访问到对象的shallow size之和。换句话说,retained size是该对象被GC之后所能回收到内存的总和。

利用内存分析工具(Memory Analyzer Tool,MAT)分析java项目内存泄露_第6张图片

Leak Suspects如下图
利用内存分析工具(Memory Analyzer Tool,MAT)分析java项目内存泄露_第7张图片
问题的详细分析信息:
利用内存分析工具(Memory Analyzer Tool,MAT)分析java项目内存泄露_第8张图片
寻找导致内存泄漏的代码点。这时往往需要打开对象依赖关系树形视图,如下

利用内存分析工具(Memory Analyzer Tool,MAT)分析java项目内存泄露_第9张图片

如何查看某一个对象占用的内存空间
1.按以下方式打开新窗口即可
利用内存分析工具(Memory Analyzer Tool,MAT)分析java项目内存泄露_第10张图片
2.输入类名(输入类的全名)
利用内存分析工具(Memory Analyzer Tool,MAT)分析java项目内存泄露_第11张图片

可见,类Test中OOMObject内存溢出.

以上是通过MAT分析Tomcat应用程序,找到内存泄露的原因。

你可能感兴趣的:(学习总结)