各位大佬, Java 程序 OOM 问题怎么分析啊

查看 67|回复 3
作者:taogen   
初步推测是 OOM ,然后查看系统日志确实是 OOM 进程被杀掉了
dmesg -T | egrep -i 'killed proces
[Mon Sep 25 03:15:33 2023] Killed process 31231 (java) total -vm: 21198476kB, anon-rss: 1920426kB, file-rss: OkB, shmem-rss:0k

oom, killed, Java, shmem-rss

gogo789   
你如果要分析为什么 oom ,主要靠日志,HeapDumpOnOutOfMemoryError 。把 hprof 的文件拉到本地,用 JvisualVM 或者 mat 分析引用链。
shalk   
1.上面只是虚拟内存,不一定代表是 OOM 之后被 kill 的。要看看 dmesg
2. 可以给 JVM 开 heap OOM dump
tdy218   
大家常说的 OOM = OOME = HeapDumpOnOutOfMemoryError, 你这遇到是 oom-killer ,你先搞清楚这两个异常的区别以及触发条件....
还有你这 Linux 操作系统的 free -m 贴一下,上面跑了多少个 java 进程、jvm 堆/元数据区/部分非堆内存怎么设置的、发生 oom-killer 的时候会打出来一堆进程的内存使用率、oom_score 等信息,这些信息全没得...
您需要登录后才可以回帖 登录 | 立即注册

返回顶部