记一次OOM的分析

本文记录了一次由于内存溢出(OOM)导致的系统异常,详细介绍了如何通过MAT(Memory Analyzer Tool)进行内存分析,包括保留现场、恢复环境和分析dump文件的步骤。重点讲解了MAT的Leak Suspects、Histogram和Dominator Tree等功能在定位内存泄露问题上的应用,最终成功定位到问题源并提供了解决方案。
摘要由CSDN通过智能技术生成

前言

测试同学反馈测试环境不能正常访问,查看日志发现OOM。虽然是测试环境,但是还是排查了一下原因,以免线上也出同样的问题。

处理步骤

1、保留现场

首先使用jmap -heap pid查看堆空间使用情况,结果发现年轻代和老年代空间都满了

还能看到的信息是JVM使用的垃圾收集器是Parallel Scavenge + Serial Old。
保留现场:
1.使用jmap -histo pid > 2020-02-21-erp-web.histo保留类的实例占比统计信息;
2.使用jmap -dump:format=b,file=2020-02-21-erp-web.dump pid > 2020-02-21-erp-web.dump保留dump文件,这个很重要;

2、尽快恢复环境

1.堆内存确实配置的有点小了,才512M,调整JVM的堆最大最小内存为1024M,-Xms=1024m -Xmx=1024m;
2.重启程序;
3.虽然是测试环境,但是也有很多人在用,必须尽快恢复,若是线上环境更应如此。

3、分析dump文件,找到原因

3.1分析工具用什么?

可选的工具有

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值