Metaspace GC 问题排查

背景描述查看应用JVM监控发现发生了连续两次 Full GC,导致 GC 的原因是什么?Full GC 监控:metaspace利用率监控:问题排查环境信息生产环境,JDK1.8关键JVM参数:-Xms4g -Xmx4g -Xmn2g -XX:MetaspaceSize=256m -XX:MaxMetaspaceSize=512m -XX:MaxDirectMemorySize=1g -XX:SurvivorRatio=10 -XX:+UseConcMarkSweepGC -XX:CM
摘要由CSDN通过智能技术生成

背景描述

查看应用JVM监控发现发生了连续两次 Full GC,导致 GC 的原因是什么?
Full GC 监控:
在这里插入图片描述
metaspace利用率监控:
在这里插入图片描述

问题排查

环境信息

生产环境,JDK1.8
关键JVM参数:

-Xms4g -Xmx4g -Xmn2g -XX:MetaspaceSize=256m -XX:MaxMetaspaceSize=512m -XX:MaxDirectMemorySize=1g -XX:SurvivorRatio=10 -XX:+UseConcMarkSweepGC -XX:CMSMaxAbortablePrecleanTime=5000

GC日志分析

在这里插入图片描述
从日志中可以看出,Full GC 是由于 metaspace 空间不足导致的。metaspace 空间主要保存的是类元信息和类常量数据等,类常量很少变化,一般是加载的类过多才会导致 GC。结合 metaspace 利用率监控可以得知,经过GC后会有约 40% 的数据会被清理掉,应该是有类被频繁加载、卸载导致 metaspace 存在大量类的垃圾数据,当发生 GC 时由于这些类早已经被卸载了,metasapce 里的类垃圾数据自然也就被释放了。

到这里大概确定了问题所在,接下来需要排查是哪些类被频繁的加载和卸载,这里使用开源的 Arthas 工具进行排查。

Arthas

使用简介

下载 arthas

sudo wget https://alibaba.github.io/arthas/arthas-boot.jar

进入arthas

java -jar arthas-boot.jar

查看加载最多的类

获取所有类信息

1.将类信息输出到 allclass.txt 文件:classloader -a > allclass.txt
2.查看 allclass.txt 文件路径:pwd
在这里插入图片描述

查看加载最多的package

1.进入 allclass.txt 文件路径
2.执行命令:

cat output.txt | sed ‘/^$/d’ | awk -F ‘.’ ‘{print $1}’ | sort | uniq -c | sort -k 1 -nr | head -20

  • 3
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
当遇到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性能优化工具或咨询服务。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值