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

Posted Agly_Charlie

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了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监控
在这里插入图片描述

参考链接

以上是关于JVM 关于-XX:-TieredCompilation 的案例 导致CPU异常高的主要内容,如果未能解决你的问题,请参考以下文章

关于JVM内存的N个问题

JVM关于JVM,你需要知道这些!!

JVM关于JVM,你需要知道这些!!

JVM关于JVM,你需要掌握这些 | 一文彻底吃透JVM系列

JVM关于JVM,你需要掌握这些 | 一文彻底吃透JVM系列

关于 JVM 内存的 N 个问题(转)