java8 matespace_JDK8记FullGC时候Metaspace内存不会被垃圾回收

在高并发场景下,一个Java应用出现Metaspace内存溢出。通过调整JVM配置,发现Full GC时Metaspace未被回收。分析GC日志,Metaspace使用量在GC前后保持不变,原因在于类加载器未释放导致元数据无法卸载。解决方法是减少不必要的类加载,避免类加载器碎片化。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

本文链接:https://blog.csdn.net/a15939557197/article/details/90635460

背景

前段时间有一个这样的需求:第三方调用接口,30分钟内调用120W次;

物理机(与线上配置一样)上压测,第一次压了20w次,没有出现问题;接着又压了20w次,出现了内存溢出问题。

java.lang.OutOfMemoryError: Metaspace

JVM配置

JAVA_OPT_MEM="

-server -Xms4096M -Xmx4096M -Xmn512M -XX:MetaspaceSize=512M -XX:MaxMetaspaceSize=512M

-XX:+UseParNewGC //新生区使用CMS(标记清理)算法进行垃圾回收

-XX:+UseConcMarkSweepGC //新生代使用并行收集器,老年代使用 CMS+串行收集器

...

...

"

初始化最大元空间是512M,

增加两个参数,在Full GC前后分别对内存做一个heap dump

-XX:+HeapDumpBeforeFullGC

-XX:+HeapDumpAfterFullGC

观察GC日志

{Heap before GC invocations=2799 (full 1):

par new generation total 471872K, used 58664K [0x00000006c0000000, 0x00000006e0000000, 0x00000006e0000000)

eden space 419456K, 9% used [0x00000006c0000000, 0x00000006c2679e10, 0x00000006d99a0000)

from space 52416K, 36% used [0x00000006dccd0

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值