记一次线上OOM内存溢出的排查历程

本文介绍了如何在Java环境中通过参数设置生成内存泄露文件,并使用Eclipse Memory Analyzer工具进行分析。作者通过分析内存泄露的定义,展示了分析过程,包括查找最大占用内存的对象,以及从日志中定位问题。最后,分享了从一篇网络文章中获取的解决方案,并提到实际环境中的验证思路。

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

# 环境准备

1. 内存泄露文件
注:在运行java项目的时候,添加参数,当内存溢出的时候可以生成hprof二进制文件,这个可以百度下
java_pid200378.hprof

2. 内存泄露分析工具
eclipse memory analyzer


# 释义

1. 内存泄露
内存泄露为程序在申请内存后,无法释放已申请的内存空间
换句话说
不再会被使用的对象或者变量占用的内存不能被回收,就是内存泄露


# 开始喽
如下图所示,是我的两个准备文件

# 文件打开页面,开始我的分析之路
点击 Leak Suspects

# 两个问题导致内存泄露,一个一个去分析

# 寻找占用内存最大的两个对象

# 这里可以一级一级的展开,查看具体的对象信息

# 重要的是从日志中分析出,内存泄露和代码中的关系,如下图所示
这张图是通过第二张图里面的①或者②点进来,拖到最下面就是下图看到的日志

# 网上搜一搜
原文连接:https://www.weixiuzhan.cn/news/show-28946.html

# 验证问题

# 小结
如果看上面那篇文章的话,会告诉你在启动类调整对应参数设置,我这里因为本身就小,升级一下就够使了,所以采用升级的方案

不过,上面的分析思路还是需要在实际的环境中跑一跑才可以验证me的猜想

大家有问题,留言交流呦

又一次的内存泄露分析(2023年1月31日)

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值