Java中内存泄露的分析
本文由发表于3年前 | J2EE | 暂无评论 |  被围观 2,469 views+
1、下面监控一下我开发环境下的Resin服务器:2、监控一段测试程序:

小哥最近在分析项目中的内存泄露情况,使用了Eclipse Memory Analyzer,移步到这里下载最新版本:

http://www.eclipse.org/mat/

我们知道,不同版本的虚拟机和JDK版本,垃圾回收机制和内存空间布局都是有所差别的,我使用的是这个版本的JDK

java version "1.6.0_26"
Java(TM) SE Runtime Environment (build 1.6.0_26-b03)
Java HotSpot(TM) Client VM (build 20.1-b02, mixed mode, sharing)
1、下面监控一下我开发环境下的Resin服务器:

首先,运行JDK bin目录下的jconsole.exe文件,链接到Resin服务器:

20141110001

进入之后,就可以查看到堆内存,类,CPU的使用情况了。

细心的读者发现了我使用的是主流的HotSpot虚拟机。选择 com.sun.management-->HotSpotDiagnostic-->操作-->dumpHeap(堆转储),在操作调用中的p0填写导出目录,点击dumpHeap即可:

20141110002

这样就可以在p0对应的输出目录中找打导出的文件了:dumpHeap.hprof

接下来启动MemoryAnalyzer, File --> Open File... 选择刚才导出的文件进行分析。

选择目录中的Path To GC Roots --> exclude weak/soft references 排除掉弱引用,剩下的才是最有可能导致内存泄露的问题:

20141110003

目前查看到的都是classloader加载到的Class文件的引用,并没有发现异常信息:

20141110004

继续观察,发现问题随时分析。

哦对了,ClassLoader也是有可能产能内存泄露的哦,详细请查看我的这篇文章:

2、监控一段测试程序:

可以通过配置Java的 -XX:+HeapDumpOnOutOfMemoryError 参数让虚拟机在出现内存溢出异常时Dump出当前的内存堆转储快照。

下面是来自深入理解Java虚拟机的例子:

/**
 * VM Args:-verbose:gc -Xms20m -Xmx20m -XX:+HeapDumpOnOutOfMemoryError
 * 限制Java堆大小为20M,不可扩展,让虚拟机在出现内存溢出异常时Dump出当前的内存堆转储快照
 * @Author zzm
 */
public class HeapOOM{
    static class OOMObject{
    }
    public static void main(String[] args){
        List<OOMObject> list = new ArrayList<OOMObject>();
        while(true){
            list.add(new OOMObject());
        }
    }
}

执行后可以发现转储快照被导出了:

Dumping heap to java_pid4148.hprof ...
Heap dump file created [24728647 bytes in 0.342 secs]
Exception in thread "main" java.lang.OutOfMemoryError: Java heap space
at java.util.Arrays.copyOf(Unknown Source)
at java.util.Arrays.copyOf(Unknown Source)
at java.util.ArrayList.ensureCapacity(Unknown Source)
at java.util.ArrayList.add(Unknown Source)
at me.arthinking.memoryleaktest.HeapOOM.main(HeapOOM.java:18)

接下来使用MemoryAnalyzer分析这个文件就可以了。

如果是内存泄露,可以进一步通过查看泄露对象到GC Roots的引用链。

如果不存在内存泄露,就应当坚持虚拟机的堆参数(-Xmx和-Xms)。

除了文章中有特别说明,均为IT宅原创文章,转载请以链接形式注明出处。
本文链接:http://www.itzhai.com/java-memory-leak-analyze.html
关键字: ,
arthinking Java技术交流群:280755654,入门群:428693174 more
分享到:
 
2014 11/10
如果您有更好的原创技术博文或者观点,欢迎投稿:admin@itzhai.com,或者关注订阅左侧浮动面板的微信号订阅IT宅itread)发送消息。
文章评论
    没有评论
给我留言

有人回复时邮件通知我
J2EE的相关文章
随机文章 本月热门 热评
1 【转】苹果新品发布会:难得的皆大欢喜 2013/10/23
2 JVM笔记 – 高效并发(线程安全与锁优化) 2015/3/2
3 8253/8254的编程约定 2011/4/26
4 数据结构笔记 – 排序算法 优化冒泡排序算法 2011/9/20
5 ExtJS拖放技术DragSource拖动到指定区域DDTarget 2011/4/13
6 使用Struts2的拦截器和自定义注解方式实现权限控制 2011/10/4
友情推荐 更多
破博客 文官洗碗安天下,武将打怪定乾坤。多么美好的年代,思之令人泪落。
Mr.5's Life 白天是一名程序员,晚上就是个有抱负的探索者
行知-追寻技术之美 关注大数据,分布式系统
我爱编程 编程成长轨迹
Cynthia's Blog 学习笔记 知识总结 思考感悟
 
欢迎关注我的公众号 IT宅
关于IT宅 文章归档

IT宅中的文章除了标题注明转载或有特别说明的文章,均为IT宅的技术知识总结,学习笔记或随笔。如果喜欢,请使用文章下面提供的分享组件。转载请注明出处并加入文章的原链接。 感谢大家的支持。

联系我们:admin@itzhai.com

Theme by arthinking. Copyright © 2011-2015 IT宅.com 保留所有权利.