groovy引起的fullGC问题排查

某服务因groovy脚本执行引发每天8-12点的FullGC报警。分析发现,GroovyShell每次执行动态生成新类,导致Metaspace内存占用增加。解决方案包括:共享GroovyShell对象并执行完后清理缓存。

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

一、问题背景

二、分析过程

  • 2.1 参数配置
  • 2.2 定位过程
  • 2.3 JVM分析
  • 2.4 问题分析

三、解决方案

一、问题背景

prometheus监控报警生效后,某服务每天的上午 8-12 点间会有fullGC的报警;

排查并解决该问题;

二、分析过程

2.1 参数配置

JVM 参数配置如下:

-Xms3g -Xmx3g -Xmn1g -XX:MetaspaceSize=128m -XX:ParallelGCThreads=5 -XX:+UseConcMarkSweepGC -XX:+UseParNewGC -XX:+UseCMSCompactAtFullCollection -XX:CMSInitiatingOccupancyFraction=80 -XX:+PrintGCDetails -XX:+PrintGCDateStamps -XX:+HeapDumpOnOutOfMemoryError 

新生代大小:1G;

新生代垃圾收集器:ParNewGC;

老年代大小:2G;

老年代垃圾收集器:ConcMarkSweepGC;

CMS触发条件:老年代内存占用达到80%及以上;

2.2 定位问题

1.由于报警的时间点都集中在上午的 8-12 点之间,怀疑是由于某个定时任务造成的;

2.定位具体的定时任务,有两个定时任务的时间设置基本满足;

任务1: 更新客户信息  
CustomerScheduleJobService.updateCustomerDataDaily  0 0/30 8,9,10,11,12 * * ?

任务2: 创建客户任务   
CustomerStaffScheduleJobService.jobCreateTask  0 10,40 7,8,9,10,11 * * ?
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值