java应用刚启动后,立刻进行压测,发现TPS结果较低,分析流程及原因如下:
1、压测过程中发现当前java进程暂用cpu过高(4核380%),检测哪个线程暂用cpu资源较大
使用命令top -Hp 31991 检测当前java进程暂用变化如下
发现线程32003/32004线程暂用cpu较高,打印堆栈信息jstack 31991 > jstack.log
把32003/32004转化16进制后printf “%x” 32004为7d03、7d04
根据堆栈信息发现C2 CompilerThread1线程。
2、分析C2 CompilerThread1原因:
定位到 C2 CompilerThread0这个线程占用了比较高的CPU。C2 Compiler 是JVM在server模式下字节码编译器,JVM启动的时候所有代码都处于解释执行模式,当某些代码被执行到一定阈值次数,这些代码(称为热点代码)就会被 C2 Compiler编译成机器码,编译成机器码后执行效率会得到大幅提升。
流量进来后,大部分代码成为热点代码,这个过程中C2 Compiler需要频繁占用CPU来运行,当大部分热点代码被编译成机器代码后,C2 Compiler就不再长期占用CPU了,这个过程也可以看作抖动。
3、修改方案:
设置JVM启动参数:-XX:CICompilerCount=threads
默认是2, 可以设置4或6。在默认值下抖动时CPU已经满载,设置成更多的线程也不一定起作用,但对于CPU“高而不满”的情况会有用,能减少抖动时间。