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

本文详细阐述了如何配置JVM生成OOM Dump文件,包括在内存不足和服务停滞时的处理方法。接着介绍了如何使用Eclipse的MAT工具对dump文件进行图形化分析,包括Windows和Linux版本的应用。最后讲述了打开分析报告,利用浏览器和MAT工具解读内存泄漏和线程情况。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

前言

  当需要的内存空间大于系统分配的内存空间时,发生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图形化工具)

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工具


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

但行益事莫问前程

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值