Java OOM 导致 Full GC 异常排查

Java OOM 导致 Full GC 异常排查

简介

当请求服务器时,服务无法响应(一般出现响应超时),查看服务日志时,出现OOM 或GC字眼,且不会输出最新日志。
本人亲身经历三个服务OOM总结的经验,请指教。

思路:
  1. 查看服务状态
  2. 输出堆栈信息
  3. 分析堆栈信息
  4. 查找解决方案
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版本
jdk8MAT v1.10.0
jdk11MAT v1.13.0
jdk17MAT v1.14.0

4. 查找解决方案

前提:MemoryAnalyzer能够分析具体对象溢出
浏览器输出MemoryAnalyzer中的溢出对象,常见的OOM内存泄漏网上都有原因及解决方案;

  • 9
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值