当前位置: 首页>编程语言>正文

【Java】JVM调优操作手册(实战篇)

在调优之前,首先要明确调优的目标,针对不同的应用场景,有不同的衡量指标:

响应时间: 关注系统对请求的响应速度,比如To C的应用,用户体验比较重要,这类应用的重点要在短时间做出响应

吞吐量: 关注特定时间段内最大化应用程序工作量,

我们的JVM调优主要集中在两个方面:调整堆大小;调整垃圾收集器。

常用的JVM参数

【Java】JVM调优操作手册(实战篇),【Java】JVM调优操作手册(实战篇)_JVM,第1张

JVM调优常规步骤

  1. 分析当前问题:也就是你为什么要进行此次调优,比如启动慢,出现卡顿,或是偶尔响应慢。
  2. 确定调优目标:比如减少内存占用,降低平均响应时间,提高吞吐量
  3. 收集GC日志
  4. 分析GC日志
  5. 调整参数,循环进行3,4,5步

【Java】JVM调优操作手册(实战篇),【Java】JVM调优操作手册(实战篇)_测试工具_02,第2张

Parallel调优参数

【Java】JVM调优操作手册(实战篇),【Java】JVM调优操作手册(实战篇)_jvm_03,第3张

CMS调优参数

【Java】JVM调优操作手册(实战篇),【Java】JVM调优操作手册(实战篇)_JVM_04,第4张

G1调优参数

【Java】JVM调优操作手册(实战篇),【Java】JVM调优操作手册(实战篇)_JVM_05,第5张

常用的命令:

虽然监控系统可以对GC情况进行实时监控,但掌握下面这些命令,去服务器进行操作也是必要的。

  • 实时分析
  1. jstat: 比如下面命令,每1000ms统计一次,每10行打印一次

jstat -gc -h10 PID 1000

也可以不用每次去找PID,利用jcmd命令

jstat -gc -h10 $(jcmd | grep "XXX.jar" | awk '{print $1}' )

  • 开始调优
  1. 查看当前参数

jinfo -flags PIDjava -XX:+PrintFlagsFinal -version | grep 参数关键字



https://www.xamrdz.com/lan/5wc1935546.html

相关文章: