tomcat 产生heapdump文件配置
2016-04-13 18:12
453 查看
系统有时会遇到OutOfMemoryError,Java堆溢出了。我们需要找到造成OutOfMemoryError原因。一般有两种情况:
1、内存泄露,对象已经死了,无法通过垃圾收集器进行自动回收;
2、内存溢出,内存中的对象都还必须存活着,这说明Java堆分配空间不足,检查堆设置大小(-Xmx与-Xms),检查代码是否存在对象生命周期太长、持有状态时间过长的情况。
想在泄漏未发生前,取堆转储文件分析, 通过jvm参数-XX:+HeapDumpOnOutOfMemoryError(XX:+HeapDumpOnCtrlBreak不知道为什么tomcat启动不了)可以让JVM在出现内存溢出是Dump出当前的内存转储快照。
当然也可以通过用jmap生产dump文件。windows通过任务管理器查看tomcat的进程pid,linux用ps命令查看进程pid,然后用jmap命令(Java5:jmap -heap:format=b <pid>;Java6:jmap -dump:format=b,file=HeapDump.bin <pid>)
2.加上:JAVA_OPTS="$JAVA_OPTS -server -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=D:\heapdump"
如下图位置:
注:其中不设-XX:HeapDumpPath时,dump出的文件在/tomcat_home/bin目录下
2.加上:set JAVA_OPTS=%JAVA_OPTS% -server -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=D:\heapdump
如下图位置:
分析dump出来的内存快照文件
可以使用分析工具进行分析,如:
Eclipse的MAT
下载地址:http://www.eclipse.org/mat/downloads.php
说明文档:http://www.vogella.com/articles/EclipseMemoryAnalyser/article.html#example_project
注意:解析过大的HeapDump可能导致Eclipse抛出OutOfMemory的错误。这时你需要手动调整Eclipse的缓存大小,可以参考官网给出的处理方式(原文连接)
Alternatively, edit the
-vmargs
-Xmx2g
-XX:-UseGCOverheadLimit
Eclipse插件版打不开的朋友可以试试 RPC版的MAT (我的232m的dump文件也打不开,难道非得用64bit的机器吗?):RPC版MAT下载地址
。
JProfile
等等;
转自:/article/4282112.html
1、内存泄露,对象已经死了,无法通过垃圾收集器进行自动回收;
2、内存溢出,内存中的对象都还必须存活着,这说明Java堆分配空间不足,检查堆设置大小(-Xmx与-Xms),检查代码是否存在对象生命周期太长、持有状态时间过长的情况。
想在泄漏未发生前,取堆转储文件分析, 通过jvm参数-XX:+HeapDumpOnOutOfMemoryError(XX:+HeapDumpOnCtrlBreak不知道为什么tomcat启动不了)可以让JVM在出现内存溢出是Dump出当前的内存转储快照。
当然也可以通过用jmap生产dump文件。windows通过任务管理器查看tomcat的进程pid,linux用ps命令查看进程pid,然后用jmap命令(Java5:jmap -heap:format=b <pid>;Java6:jmap -dump:format=b,file=HeapDump.bin <pid>)
在tomcat中设置jvm参数
linux系统中
1.打开/tomcat_home/bin/catalina.sh文件2.加上:JAVA_OPTS="$JAVA_OPTS -server -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=D:\heapdump"
如下图位置:
注:其中不设-XX:HeapDumpPath时,dump出的文件在/tomcat_home/bin目录下
Windows系统中
1.打开/tomcat_home/bin/catalina.bat文件2.加上:set JAVA_OPTS=%JAVA_OPTS% -server -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=D:\heapdump
如下图位置:
分析dump出来的内存快照文件
可以使用分析工具进行分析,如:
Eclipse的MAT
下载地址:http://www.eclipse.org/mat/downloads.php
说明文档:http://www.vogella.com/articles/EclipseMemoryAnalyser/article.html#example_project
注意:解析过大的HeapDump可能导致Eclipse抛出OutOfMemory的错误。这时你需要手动调整Eclipse的缓存大小,可以参考官网给出的处理方式(原文连接)
Alternatively, edit the
MemoryAnalyzer.inito contain:
-vmargs
-Xmx2g
-XX:-UseGCOverheadLimit
Eclipse插件版打不开的朋友可以试试 RPC版的MAT (我的232m的dump文件也打不开,难道非得用64bit的机器吗?):RPC版MAT下载地址
。
JProfile
等等;
转自:/article/4282112.html
相关文章推荐
- tomcat优化协议
- myElipse项目导不进tomcat解决方法
- Servlet+Tomcat制作出第一个运行在Tomcat上的Java应用程序
- Mac OS 搭建 Jenkins 实践(Tomcat + jenkins.war)
- tomcat架构分析(valve机制)
- tomcat部署项目的各种方式
- Ubuntu 配置 Tomcat
- 关于tomcat优化记录与思路
- maven project 部署到tomcat时项目部署不上去
- Servlet和Tomcat部署
- Mac 安装Tomcat
- 使用JMX监控Tomcat
- Tomcat重启负载高问题定位
- 启动Tomcat出现Using CATALINA_BASE
- Apache与Tomcat联系及区别
- maven tomcat1.7环境下构建javaweb 项目
- Tomcat7插件+overlays不能热部署调试如何解
- nginx + tomcat 配置,静态资源直接使用nginx
- 配置tomcat
- java.lang.UnsatisfiedLinkError: D:\Tomcat\apache-tomcat-7.0.37\bin\tcnative-1.dll: Can't load AMD 6