记一次 频繁Full GC JVM调优

记一次 频繁Full GC JVM调优

背景

观察服务监控平台的时候发现,几乎 20分钟就会触发一次 Full GC;

问题定位

因为对我们系统JVM参数都很熟悉,所以问题定位很快,通过监控就定位到 每次触发FullGC 的时间 都与MetaSapceSize达到512M的时间点相吻合,因为我们系统配置的MaxMataSpaceSize=512M;

GC次数
MetaSpace内存

查询JVM参数命令:

  1. jps -l 获取到启动应用的pid
  2. jinfo pid
    JVM配置参数

问题解决

我们都知道 jinfo 可以动态调整JVM参数,不需要重启,那么我们就直接在线调整看一下调优效果。
在这里插入图片描述

哦哦,jinfo 不支持 MaxMetaSpaceSize 参数的动态修改;jinfo 可以直接动态修改的参数是很有限的,只有标注了 manageable的 才是可以修改的;
在这里插入图片描述
既然jinfo不行,那我们就直接修改服务器JVM配置文件,重启服务;
这个需要你了解 你们JVM配置文件哈,例如我们是在应用下面的setenv.sh文件中;
这边 我修改MaxMetaSpaceSize=512m => MaxMetaSpaceSize=1g;

修改前:
在这里插入图片描述
修改后:
在这里插入图片描述
服务重启后:jinfo pid 参数如下,修改成功;
在这里插入图片描述

第二天 我们再看一下FullGC 的情况:

对比下两台机器:图1 是调整过的机器,图2 是未调整过的机器,我们可以看到FullGC频率明显降低,图2:原先大约半小时一次,图1:调整后大约两小时一次;
在这里插入图片描述
在这里插入图片描述

当然了,这只是简单的MetaSpaceSize的调整,后续我还会继续探索优化方式,争取FullGC频率下降至天级别。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值