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监控
参考链接
- java - What exactly does -XX:-TieredCompilation do? - Stack Overflow
- 基本功 Java即时编译器原理解析及实践 - 美团技术团队
- 什么是即时编译(JIT)!?OpenJDK HotSpot VM剖析-InfoQ
以上是关于JVM 关于-XX:-TieredCompilation 的案例 导致CPU异常高的主要内容,如果未能解决你的问题,请参考以下文章
JVM关于JVM,你需要掌握这些 | 一文彻底吃透JVM系列