Java应用刚启动压测结果偏低原因

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“高而不满”的情况会有用,能减少抖动时间。

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值