一份超实用的 OOM 内存泄露速查备忘录

公众号关注 「奇妙的 Linux 世界」

设为「星标」,每天带你玩转 Linux !

f7185fdabc5d5370b653755cb18bda01.jpeg


本文整理了一份OOM内存泄露问题速查备忘录,详细见下文。

1、核心步骤

  1. top、free、df三连,查看CPU、内存、磁盘的大致情况。

  2. netstat -lp 查看端口占用情况。

  3. 导出内存dump文件:

# 保存了堆内存现场 
jmap -dump:format=b,file=heap.dump pid
# 强制保存了堆内存现场
jmap -F -dump:format=b,file=heap.dump pid
  1. 保存线程栈:

# 保存了线程栈的现场
jstack pid > jstack.log

2、辅助工具

  • jstat -gc[gcutil] pid [interval]查看JVM垃圾回收情况。通过 jstat 查看 GC 信息,首先就是判断 GC 时间是否较长,GC 发生是否频繁,然后看是否经常性进行 FullGC。

# 如:jstat -gc pid 1000,持续跟踪如1S一次。查看java堆的状况,显示具体数值。
jstat -gc pid 1000
# 通过 jstat -gcutil 5 1000命令查看GC信息,其中5代表进程号,1000代表显示时间。查看堆中各个区域已使用空间占其总空间的百分比。
jstat -gcutil pid 1000
79e4ddec1c1790c48128a0114b5cd258.png 4e152a3e74f454ddaa4b2be042a5b9ec.png
  • 借助MAT(Eclipse Memory Analyzer)工具分析dump文件,分析内存情况。

  • 直接用文本工具打开jstack文件,分析线程占用情况。

  • 借助VisualVM更直观:

76ef5ae44daeafefd8b805aa205b77c8.png

3、分析过程

3.1、分析线程栈

直接通过文本工具打开jstack.log,搜索业务相关包名,应该大致能定位出问题:

5484a09d7278eec0de1571e48e06f5e8.png


3.2、分析内存

 1. 用MAT工具打开dump文件

be80b7a43f4f295242c7897ea7676f1f.png
2. 一般打开Histogram视图,这样能快速地发现问题,也可以打开Leak Suspects(泄露嫌疑),如下图: e8fbb2eb8f4cfb5cab7acce64f7d1e27.png

寻找这个对象被哪些地方引用了,如下图:

0654c4e6d1eec4ac4de62f87253fa88c.png

查看大对象,找出自己业务相关的关键引用:

e24dad8ec86cb750b817cbdd74680472.png 1c0194f2e01fa1ca52b60610ca3e8212.png 7b844d0a9141e135a7193ca2e34be510.png

根据上面GC Roots的结果,在结合自身的业务代码排查下,一般都会找到线索,比如:

  • 某个线程远程调用了接口返回的对象,一直被使用未能释放

  • 每次执行的数据量过大

  • 流没有关闭

  • 死循环 或者 递归次数太多

  • 定时任务执行频率过高,在任务没执行完毕时又在持续执行,导致积压了大量对象

  • ......

4、总结

本文整理了一份OOM内存泄露问题速查备忘录。核心内容是:

  • top、free、df三连,然后netstat、jstat工具跟上。

  • 紧接着赶紧jmap、jstack保存现场,然后重启应用。

  • MAT分析问题,修改问题,重新发布。

本文转载自:「不焦躁的程序员」,原文:https://url.hi-linux.com/gYZYu,版权归原作者所有。欢迎投稿,投稿邮箱: editor@hi-linux.com。

9429985565c9c30666a6c7aefc287f73.gif

最近,我们建立了一个技术交流微信群。目前群里已加入了不少行业内的大神,有兴趣的同学可以加入和我们一起交流技术,在 「奇妙的 Linux 世界」 公众号直接回复 「加群」 邀请你入群。

baebb31227d882f83e167d22df940d0b.png

你可能还喜欢

点击下方图片即可阅读

61717bd68d8808b3e33466d6a121166a.jpeg

如何优雅的终止 Docker 容器

78d4f6be6c988368668e89b5071f6615.png
点击上方图片,『美团|饿了么』外卖红包天天免费领

37dce9df57a2e95ce245bad2b732ed5a.png

更多有趣的互联网新鲜事,关注「奇妙的互联网」视频号全了解!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
当出现OOM(Out of Memory)内存溢出错误时,可以采取以下步骤来进行分析: 1. 看错误日志:首先,检应用程序或服务器的错误日志,找与内存溢出相关的错误消息。错误消息通常会提供一些有关问题的线索。 2. 检内存使用情况:使用监控工具(如JConsole、VisualVM等)来监视应用程序的内存使用情况。观察内存使用量是否持续增长,以及峰值内存使用量是否接近系统可用内存。 3. 内存分析工具:使用内存分析工具(如Eclipse Memory Analyzer、Java VisualVM等)来分析堆内存中的对象分布和引用关系。这些工具可以帮助你找到内存泄漏或者过多使用内存的地方。 4. 堆转储文件分析:如果应用程序发生了OOM错误并生成了堆转储文件(heap dump),可以使用堆转储文件分析工具进行分析。这些工具可以帮助你找到导致内存溢出的对象和其引用链。 5. 代码审:仔细检应用程序的代码,特别是与内存管理相关的部分。检是否有不必要的对象创建、未及时释放的资源、循环引用等问题。 6. 调整JVM参数:根据应用程序的需求和硬件资源,适当调整JVM的堆内存大小(-Xmx和-Xms参数)、垃圾回收器算法(-XX:+UseParallelGC、-XX:+UseConcMarkSweepGC等)等参数。 通过以上步骤,你应该能够定位并解决OOM内存溢出问题。但请注意,内存溢出的原因可能有多种,需要根据具体情况进行分析和解决。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值