在调优之前,首先要明确调优的目标,针对不同的应用场景,有不同的衡量指标:
响应时间: 关注系统对请求的响应速度,比如To C的应用,用户体验比较重要,这类应用的重点要在短时间做出响应
吞吐量: 关注特定时间段内最大化应用程序工作量,
我们的JVM调优主要集中在两个方面:调整堆大小;调整垃圾收集器。
常用的JVM参数
JVM调优常规步骤
- 分析当前问题:也就是你为什么要进行此次调优,比如启动慢,出现卡顿,或是偶尔响应慢。
- 确定调优目标:比如减少内存占用,降低平均响应时间,提高吞吐量
- 收集GC日志
- 分析GC日志
- 调整参数,循环进行3,4,5步
Parallel调优参数
CMS调优参数
G1调优参数
常用的命令:
虽然监控系统可以对GC情况进行实时监控,但掌握下面这些命令,去服务器进行操作也是必要的。
- 实时分析
jstat
: 比如下面命令,每1000ms统计一次,每10行打印一次jstat -gc -h10 PID 1000
也可以不用每次去找PID,利用jcmd命令
jstat -gc -h10 $(jcmd | grep "XXX.jar" | awk '{print $1}' )
- 开始调优
- 查看当前参数
jinfo -flags PIDjava -XX:+PrintFlagsFinal -version | grep 参数关键字