0%

Tomcat内存泄漏存入dump文件

背景

    很多Tomcat进程退出(或者进程假死),都是由于频繁的抛出OutOfMemeoryError导致的。

    为了让tomcat退出前或者发生OutOfMemeoryError时自动dump堆栈信息,方便事后排查问题,我们可以做如下操作:

  1. 在tomcat启动参数中加入两个参数 -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=D:\tomcat

  2. 重启tomcat

参数说明

(1)-XX:+HeapDumpOnOutOfMemoryError 表示当JVM发生OOM时,自动生成DUMP文件。 
(2)-XX:HeapDumpPath=存储文件/目录 表示生成DUMP文件的路径

诊断内存溢出是一个有难度的事情,可以在生产环境试一试下面的参数,在发生内存溢出OutOfMemoryError时做HeapDump并保存到文件,然后分析该文件看是否能查到蛛丝马迹。

1
2
3
set JAVA_OPTS=-Xms1G -Xmx4G 
-XX:+HeapDumpOnOutOfMemoryError
-XX:HeapDumpPath=D:\tomcat

分析工具

Java Heap Dump文件格式是一个HPROF二进制格式,可以用MAT(Memory Analyzer)进行分析。

下载地址:Eclipse Memory Analyzer Open Source Project | The Eclipse Foundation