JVM 关于-XX:-TieredCompilation 的案例 导致CPU异常高

JVM 关于-XX:-TieredCompilation 的案例 导致CPU异常高

背景

项目出现的现象就是:我们有个服务POD每运行一段时间后会出现cpu异常。服务有个大接口(返回数据JSON 30-40M左右),定时几分钟请求进来。运行时间长了之后,会出现明显的毛刺。

下图是POD服务的CPU监控
在这里插入图片描述

下图是主机的CPU监控
在这里插入图片描述

排查原因:

一开始以为是JSON的工具的问题,因为项目用的是GSON工具,但是通过验证不会出现这个情况,40M的左右的请求不会导致这么验证的现象。最后排查定位使用了JVM参数 -XX:-TieredCompilation

TieredCompilation

-XX:-TieredCompilation (关闭)
-XX:+TieredCompilation (开启)

这个参数主要用于是否开启JVM的分层编译,JDK8之后默认是开启。TieredCompilation的参数,如果关闭它,会导致CodeCache变小。这个参数应该要配合另一个codeCache参数使用的,不然容易导致codeCache不够用,导致服务在长时间运行后程序整个执行效率降低

优化后效果

把这个参数去除后,CPU正常,也不会出现毛刺
下图是POD服务的CPU监控
在这里插入图片描述

下图是主机的CPU监控
在这里插入图片描述

参考链接

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值