一、调优基本概念

jvm性能调优的三个基本组件

1.堆大小调整

2.垃圾收集器调整

3.JIT编译器

img

通常在调优java应用程序时,重点是一下两个目标之一

响应性:应用程序或系统对请求的数据进行相应的速度,对于专注于响应性的应用程序,长的暂停时间是不可接受的,重点是在短时间内做出回应。

吞吐量:侧重于在特定时间段内最大化应用程序的工作量,对于专注于吞吐量的应用程序,高暂停时间是可以接受的。由于高吞吐量的应用程序在较长时间内专注于基准测试,因此不需要考虑快速响应时间。

用户代码执行时间/(用户代码执行时间+垃圾回收时间)

二、JVM常用参数

img

三、GC调优思路

img

通用GC参数

img

img

img

img

四、JIT编译器优化参数

img

五、调优

(1)根据需求进行JVM规划和预调优

(2)优化运行JVM环境(慢、卡顿怎么优化)

(3)解决JVM运行过程中出现的各种问题

调优,从规划开始

1.调优,从业务场景开始

2.无监控(压力测试,能看到结果),不调优

步骤:

(1)熟悉业务场景(没有最好的垃圾回收器,只有最合适的垃圾回收器)

响应时间、停顿时间 【CMS、G1、ZGC】,需要给用户作响应

吞吐量 = 用户时间/(用户时间+GC时间)【PS】

(2)选择回收器组合

(3)计算内存需求、经验值

(4)选定CPU(越高越好)

(5)设定年代大小、升级年龄

(6)设定日志参数

1
2
-Xloggc:/opt/xxx/logs/xxx-xxx-gc-%t.log -XX:+UseGCLogFileRotation -XX:NumberOfGCLogFiles=5
-XX:GCLogFileSize=20M -xx:+PrintGCDetails -XX:+PrintGCDateStamps -XX:+PrintGCCause

或者每天产生一个日志文件

(7)观察日志情况

运行环境

1.系统CPU经常 100%,如何调优

CPU 100% 一定有线程在占用系统资源

(1)找出哪个进程的 CPU 高 【top】

(2)该进程中哪个线程的 CPU 高 【top -Hp】

(3)导出该线程的堆栈 【jstack】

(4)查找哪个方法(栈帧)的消耗时间 【jstack】

(5)工作线程占比高、垃圾回收线程占比高

2.系统内存飙高,如何查找问题

(1)导出堆内存 【jmap】

(2)分析 【jhat 、jvisualvm、jprofiler】

怎么定位 OOM 问题:

1.已经上线的系统不用图形界面,用cmdline、arthas

2.图形界面用在什么地方?测试,测试的时候进行监控(压测观察)