Metaspace GC 问题排查

本文详细描述了一次由于 Metaspace 导致的 Full GC 问题的排查过程,包括环境信息、GC 日志分析、使用 Arthas 查看加载最多的类和调用链路。问题根源在于 sun.reflect.GeneratedSerializationConstructorXXX 类的频繁加载和卸载,通过增加 Metaspace 参数和优化反射调用解决了问题。
摘要由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
在这里插入图片描述
sun 包是最多的,这里截图为发生GC后

查看package前两段

cat output.txt | grep sun | awk -F ‘.’ ‘{print $1 “.” $2}’ | sort | uniq -c | sort -k 1 -nr | head -10

可以看到这里 sun.reflect 占多数,其中主要为:

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值