- 浏览: 257582 次
- 性别:
- 来自: 广州
文章分类
最新评论
-
郑涵魁:
这才是好文啊
一次使用Eclipse Memory Analyzer分析Tomcat内存溢出 -
silvia016:
很有用,非常感谢
一次使用Eclipse Memory Analyzer分析Tomcat内存溢出 -
chengcwn:
好文章,多谢分享!
一次使用Eclipse Memory Analyzer分析Tomcat内存溢出 -
young7:
不错,特别是那个参考文章
JAVA调用Shell脚本--及阻塞的解决办法 -
zhujianbogo:
什么邮件列表,能说下解决方案吗? 谢谢 。 我也遇到这个问题了 ...
Tomcat与apache2集群的问题
前言
在平时开发、测试过程中、甚至是生产环境中,有时会遇到OutOfMemoryError,Java堆溢出了,这表明程序有严重的问题。我们需要找造成OutOfMemoryError原因。一般有两种情况:
1、内存泄露,对象已经死了,无法通过垃圾收集器进行自动回收,通过找出泄露的代码位置和原因,才好确定解决方案;
2、内存溢出,内存中的对象都还必须存活着,这说明Java堆分配空间不足,检查堆设置大小(-Xmx与-Xms),检查代码是否存在对象生命周期太长、持有状态时间过长的情况。
以上是处理Java堆问题的思路,具体是怎么进行分析,这里介绍的是使用Eclipse Memory Analyzer tool(MAT)工具分析的过程。
2、内存溢出,内存中的对象都还必须存活着,这说明Java堆分配空间不足,检查堆设置大小(-Xmx与-Xms),检查代码是否存在对象生命周期太长、持有状态时间过长的情况。
以上是处理Java堆问题的思路,具体是怎么进行分析,这里介绍的是使用Eclipse Memory Analyzer tool(MAT)工具分析的过程。
生成dump文件
通过jvm参数--XX:-HeapDumpOnOutOfMemoryError可以让JVM在出现内存溢出是Dump出当前的内存转储快照;
或者,用jmap生产dump文件,win通过任务管理器查看tomcat的进程pid,linux用ps命令查看进程pid,然后用jmap命令(Java5:jmap -heap:format=b <pid>;Java6:jmap -dump:format=b,file=HeapDump.bin <pid>)。
我这里使用的是,我一生产环境项目,运行一段时间大概3周的样子,就会报OutOfMemoryError。(ps:这个项目出现这种情况已经有好长一段时间了,我们之前的做法是定期的重启tomcat,没有去分析它的原因。)JDK64位主要参数:-Xmx3078M -Xms3078M -XX:PermSize=1024M -XX:MaxPermSize=1024M,内存还是蛮大的。
MAT安装与介绍
下载地址:http://www.eclipse.org/mat/downloads.php。
通过MAT打开dump出来的内存文件,打开后如下图:
从上图可以看到它的大部分功能。
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之后所能回收到内存的总和。
我们发现ThreadLocal和bingo.persister.dao.Daos类的对象占用了很多空间。
Dominator Tree如下图:
我们发现quartz的定时器的工作线程(10个)占了很多的内存空间
Top consumers如下图:
这里显示了内存中最大的对象有哪些,他们对应的类是哪些,类加载器classloader是哪些。
有些时候,我们在这里就可以看到代码泄露的位置。
Leak Suspects如下图:
从那个饼图,该图深色区域被怀疑有内存泄漏,可以发现整个heap才250M内存,深色区域就占了34%。后面的描述,告诉我们quartz线程占用了大量内存,并指出system class loader加载的"java.lang.ThreadLocal"实例的内存中聚集(消耗空间),并建议用关键字"java.lang.ThreadLocal$ThreadLocalMap$Entry[]"进行检查。所以,MAT通过简单的报告就说明了问题所在。
通过Leak Suspects的Problem Suspect 1点击【Details »】,
如下图如下图所示的上下文菜单中选择 List objects -> with outgoning references, 查看ThreadLocal都应用了些什么对象。
现在看到ThreadLocal中引用的对象如下图:
是dao对象
ps:该dao对象包含一个轻量级的ORM关系内容,所以Retained size比较大。
下面继续查看dao的gc ROOT
如下图所示的上下文菜单中选择 Path To GC Roots -> exclude weak references, 过滤掉弱引用,因为在这里弱引用不是引起问题的关键。
从下图中,可以看到在org.quartz.simpl.SimpleThreadPool中保存了daos的引用。所以可以得出是是因为定时器在运行的过程中持有大量的Daos对象应起了内存泄露。为什么会有那么多的Daos呢,Daos不是一个无状态的单例的、可以重用的吗?继续查看spring配置文件发现Daos的bean配置成scope="prototype",导致定时任务又是每次调用都生产新的Daos实例。由于是Daos是无状态的,修改为单例的,问题解决。
以上是通过MAT分析Tomcat应用程序,找到内存泄露的原因,并解决。
评论
7 楼
郑涵魁
2016-05-03
这才是好文啊
6 楼
silvia016
2016-04-19
很有用,非常感谢
5 楼
chengcwn
2015-08-12
好文章,多谢分享!
4 楼
bingyingao
2013-01-25
好文章,mark
3 楼
chuchu521
2012-08-31
还是不太明白怎样去分析!!!
2 楼
libo_591
2012-04-17
讲解的很详细,好文
1 楼
jyjava
2012-04-16
lz这个文章很好,对于大型项目很有帮助,
发表评论
-
Java文件读写数据流
2012-08-30 20:30 3757数据流可分节点流( ... -
apache2.2+tomcat超时503
2012-03-26 10:35 3430最近apache2.2+tomcat5.5.28(两个) ... -
Tomcat与apache2集群的问题
2012-03-16 14:53 2486最近在Tomcat与apache2集群的问题的应用程序中 ... -
JVM的参数设置的一个要点
2012-03-11 00:07 2561JVM参数的设置(特别是 –Xmx –Xms –Xmn ... -
【转载】理解Heap Profling名词-Shallow和Retained Sizes
2012-03-06 17:22 2917转载请注明原文链接:h ... -
更改eclipse author的默认名字(作者)
2011-09-07 12:39 1678在eclipse的目录下找到eclipse.in ... -
【转载】java.lang.OutOfMemoryError: PermGen space及其解决方法
2011-08-27 12:18 1252java.lang.OutOfMemoryError: P ... -
JAVA NIO
2011-08-19 22:25 716NIO流是一个比IO流(字节字符)效率高很多,因为是以块 ... -
XMLGregorianCalendar 与 Date 转换
2011-06-28 17:01 1946XMLGregorianCalendar 与 Date ... -
Web Service 的描述语言WSDL说明
2011-05-27 10:28 1211<?xml version="1. ... -
spring+quartz的配置文件
2011-05-26 21:23 1244spring+quartz的配置文件 &l ... -
JAVA调用Shell脚本--及阻塞的解决办法
2011-05-16 13:13 8893用java调用shell,使用 Process p=Runt ... -
WIN7安装WebSphere6.1
2011-03-23 12:55 0首先是安装,我们决定安装WebSphere6.1。 ... -
Jbpm4常用操作
2011-03-06 15:00 2655Jbpm4常用操作 一、ProcessEngine:流程 ... -
ThreadLocal
2010-11-08 21:40 866ThreadLocal -
小记--tomcat 常见问题
2010-10-12 22:29 11631. tomcat 6 undepl ... -
SimpleDateFormat用法说明
2010-09-19 13:02 1434关于java.text.SimpleDateFormat。 ... -
常用的jar包总结(4)
2010-08-13 12:34 1740最近用新的一套web框架做项目,有很多常用的包集成在里面。 ... -
常用的jar包总结(3)
2010-08-11 23:27 2090最近用新的一套web框架做项目,有很多常用的包集成在里面 ... -
常用的jar包总结(2)
2010-08-11 23:27 1915最近用新的一套web框架做项目,有很多常用的包集成在里面 ...
相关推荐
本文将详细讲解如何使用Memory Analyzer Tool (MAT) 这款强大的工具来分析Tomcat的内存溢出问题。 MAT是IBM开发的一款专门用于分析Java heap dump的工具,它可以帮助开发者深入理解内存分配、对象生命周期以及内存...
- **MAT (Memory Analyzer Tool)**:Eclipse出品的专业内存分析工具,用于分析heap dump文件。 5. **解决步骤**: - 使用上述工具收集内存使用情况,查看是否存在内存泄漏或异常增长的对象。 - 调整JVM参数,...
MAT,全称Memory Analyzer Tool,是Eclipse基金会提供的一款强大的Java内存分析工具,主要用于分析Java应用程序的内存使用情况,特别是对堆内存的深入分析。它能够帮助开发者定位内存泄漏、过大对象以及引用链过长等...
2. **使用MemoryAnalyzer分析**: MemoryAnalyzer是一款由Eclipse提供的免费内存分析工具,它可以独立使用也可以作为Eclipse插件集成在IDE中。 3. **配置MemoryAnalyzer**: 启动MemoryAnalyzer工具,并在`Memory...
- 分析堆转储文件(heap dump),使用MAT(Memory Analyzer Tool)、Eclipse Memory Analyzer等工具找出内存泄漏的源头。 4. **优化垃圾回收策略** - 根据应用特性选择合适的垃圾回收器(如G1、CMS、Parallel等)...
4. **使用内存分析工具**:定期进行内存分析,使用MAT等工具找出内存占用高的对象,分析其生命周期和引用关系,定位内存泄漏源头。 5. **日志监控**:加强日志监控,对异常情况快速响应,及时获取到OOM等关键信息。...
2. 使用外部工具:例如使用 Eclipse 的 Memory Analyzer Tool (MAT) 工具来分析程序的内存使用情况。 结论 Java.lang.OutOfMemoryError: Java heap space 是一种常见的 Java 错误,解决该问题需要从多方面入手,...
MAT,全称Memory Analyzer Tool,是Eclipse基金会提供的一个强大的Java堆内存分析工具。它能够帮助开发者检测和解决Java应用程序中的内存泄漏问题,优化内存使用效率。本文将深入探讨MAT工具及其在测试类中的应用。 ...
这时需要使用内存分析工具,如VisualVM或MAT(Memory Analyzer Tool),来分析堆转储文件,找出哪些对象占用过多内存并查找泄漏源头。 3. **优化对象使用**:避免创建大量大对象,尤其是长时间存活的对象,因为它们...
- 使用工具如VisualVM或MAT (Memory Analyzer Tool)来检测和定位潜在的内存泄漏点。 - 定期清理无用的临时文件和缓存数据。 4. **合理设置线程池大小**: - 在使用线程池时,合理设置最大线程数,避免因线程...
- 使用内存分析工具如VisualVM、Eclipse Memory Analyzer (MAT) 或 JProfiler 来监控应用内存使用情况,并识别潜在的内存泄漏问题。 - 仔细检查代码逻辑,确保所有不再使用的对象都被适当地设置为`null`,以便垃圾...