OOM 问题排查思路以及处理工具

OOM 发生的位置

五个区域会发生OOM:堆内存、元空间、本地方法栈、虚拟机栈、直接内存。

在这里插入图片描述

jvm 参数配置

导出JVM dump 的方法

MAT 工具分析

MAT 工具分析参数说明

在这里插入图片描述
retained Heap :回收后的堆大小
Shallow Heap:对象本身引用占用大小
Histogram:直方图
retained Heap 与Shallow Heap区别
https://blog.csdn.net/a740169405/article/details/53610689
分析快照文件的思路或者方法
1.内存占用过大的对象是什么?
–MAT–Histogram 直方图 一般是按照占用内存大小倒叙排列
2.这个对象被谁引用?
–MAT–dominator_tree 用来分析对象的调用链
3.具体发生的代码在哪一行?
–MAT–thread_overview 用来查看对象调用的现场见截图,这里面有现场的调用链和堆栈信息

在这里插入图片描述

发生OOM的一般的原因

1.高并发下第三方中间件 创建对象过多的缓存区,导致内存不够,发生OOM
2.代码原因,比较小

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
当遇到Metaspace的OOM异常时,可以尝试以下排查处理方法: 1. 增加Metaspace内存空间: - 通过调整JVM参数来增加Metaspace的内存空间,可以使用`-XX:MetaspaceSize`和`-XX:MaxMetaspaceSize`参数来设置初始大小和最大大小。 - 适当增加Metaspace的内存空间可以缓解OOM异常,但需要注意不要过度分配内存导致其他部分受影响。 2. 检查是否存在大量动态生成的类: - 使用CGLIB、反射等方式动态生成类会消耗Metaspace的内存。 - 检查代码中是否存在频繁动态生成类的逻辑,考虑优化或减少动态生成类的使用。 3. 检查字符串常量的使用: - Metaspace也存储字符串常量,过多的字符串常量会增加Metaspace的内存压力。 - 检查代码中是否存在大量重复的字符串常量,可以使用字符串常量池或intern()方法来避免重复创建字符串对象。 4. 分析堆栈信息和内存快照: - OOM异常发生时,记录相关堆栈信息和内存快照。 - 使用工具(如MAT、VisualVM等)分析堆栈信息和内存快照,找出可能存在的内存泄漏问题。 5. 优化代码和资源管理: - 检查代码中是否存在不必要的类加载、资源加载或资源未释放的情况。 - 优化代码逻辑,避免重复加载和使用不必要的资源。 6. 升级JDK版本: - Metaspace的实现在不同的JDK版本中可能会有差异,升级到较新的JDK版本可能会提供更好的Metaspace管理和性能。 7. 参考官方文档和社区资源: - 参考Java官方文档、Oracle官方文档以及相关社区资源,了解Metaspace的工作原理和最佳实践。 - 在问题解决过程中,可以参考其他开发者的经验分享和解决方案。 重要的是,处理Metaspace的OOM异常需要综合考虑代码、配置和环境等多个因素,根据具体情况采取相应的措施。如果问题持续存在或难以解决,可以考虑寻求专业的Java性能优化工具或咨询服务。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值