Java OOM 导致 Full GC 异常排查
简介
当请求服务器时,服务无法响应(一般出现响应超时),查看服务日志时,出现OOM 或GC字眼,且不会输出最新日志。
本人亲身经历三个服务OOM总结的经验,请指教。
思路:
- 查看服务状态
- 输出堆栈信息
- 分析堆栈信息
- 查找解决方案
1. 查看服务状态
1.1 查看服务进程PID
# linux 搜索"java"进程
ps -ef |grep java
# java 查看服务
jps -l
1.2 查看堆栈状态
# 查看GC回收情况(每1000毫秒输出一次,共输出5次)
jstat -gcutil [pid] 1000 5
# 异常显示:FGC 比 YGC 多
# 查看进程堆内存信息
jmap -heap [pid]
# 异常显示: 幸存者区(From Space 和 To Space) 都是占用0.0%;
# 伊甸园(Eden Space)、老年代(PS Old Generation)占用 > 90%
2. 输出堆栈信息
# 输出当前堆信息
jmap -dump:format=b,file=dump.hprof [pid]
# 设置vm参数,出现OOM时自动保存堆信息(重启服务生效)
-XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=dump.hprof
3. 分析堆栈信息
使用jvisualvm(jdk自带工具,位于jdk/bin目录中)分析【普通】
- 将dump.hprof导入jvisualvm,查看对象数量及内存。
使用MemoryAnalyzer Tool【MAT】(eclipse旗下)分析【专业堆分析工具】【推荐】
- 将dump.hprof导入MAT工具,自动分析内存对象。
- 注意:MAT对应的JDK版本,参考:Eclipse对应的JDK版本
java版本 | MAT版本 |
---|---|
jdk8 | MAT v1.10.0 |
jdk11 | MAT v1.13.0 |
jdk17 | MAT v1.14.0 |
4. 查找解决方案
前提:MemoryAnalyzer能够分析具体对象溢出
浏览器输出MemoryAnalyzer中的溢出对象,常见的OOM内存泄漏网上都有原因及解决方案;