jvm oom内存溢出,导出dump,使用mat进行问题分析

前言

  当需要的内存空间大于系统分配的内存空间时,发生OOM;客户线上环境基本每2周挂一次,暂时编写了脚本自启动应用,需要去定位原因


1.生成Dump文件

1.1 让JVM在遇到OOM(OutOfMemoryError)时生成Dump文件

在应用中添加JVM参数:

-XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=/data/log/sdc

1.2 在服务僵死时,jmap导出

执行jmap -dump:format=b,file=文件名 进程对应的pid

如:

jmap -dump:format=b,file=sdc.hprof 124108

file:保存路径及文件名 pid:进程编号(linux通过ps aux查看)


2. 分析dump文件(使用eclipse的mat图形化工具)

注: 生成环境使用的版本为jdk8,最新的mat不支持,需要用 之前发行的版本,使用1.11.0版本

2.1 下载windows版本,直接打开(若dump文件很小)

2.2 下载linux版本,上传到服务器后解压(若dump文件很大)

进入解压后的mat目录,查看所有文件:

编辑MemoryAnalyzer.ini,调大最大使用内存

配置完成后,在服务中分析dump文件./ParseHeapDump.sh dump文件路径 org.eclipse.mat.api:suspects org.eclipse.mat.api:overview org.eclipse.mat.api:top_components

./ParseHeapDump.sh /data/log/sdc/sdc.hprof org.eclipse.mat.api:suspects org.eclipse.mat.api:overview org.eclipse.mat.api:top_components

在dump文件所在的路径下生成报告文件

把报告文件拷贝到本地磁盘


3. 打开分析报告

3.1 使用浏览器浏览

  解压缩以.zip结尾的文件,解压后,使用浏览器打开index.html文件内容,查看分析报告

查看内存泄漏排查: 查看对象占据内存空间的比例

查看线程:

3.2 使用eclipse的mat工具


经验分享 程序员 微信小程序 职场和发展