一、调优基本概念
jvm性能调优的三个基本组件
1.堆大小调整
2.垃圾收集器调整
3.JIT编译器
通常在调优java应用程序时,重点是一下两个目标之一
响应性:应用程序或系统对请求的数据进行相应的速度,对于专注于响应性的应用程序,长的暂停时间是不可接受的,重点是在短时间内做出回应。
吞吐量:侧重于在特定时间段内最大化应用程序的工作量,对于专注于吞吐量的应用程序,高暂停时间是可以接受的。由于高吞吐量的应用程序在较长时间内专注于基准测试,因此不需要考虑快速响应时间。
用户代码执行时间/(用户代码执行时间+垃圾回收时间)
二、JVM常用参数
三、GC调优思路
通用GC参数
四、JIT编译器优化参数
五、调优
(1)根据需求进行JVM规划和预调优
(2)优化运行JVM环境(慢、卡顿怎么优化)
(3)解决JVM运行过程中出现的各种问题
调优,从规划开始
1.调优,从业务场景开始
2.无监控(压力测试,能看到结果),不调优
步骤:
(1)熟悉业务场景(没有最好的垃圾回收器,只有最合适的垃圾回收器)
响应时间、停顿时间 【CMS、G1、ZGC】,需要给用户作响应
吞吐量 = 用户时间/(用户时间+GC时间)【PS】
(2)选择回收器组合
(3)计算内存需求、经验值
(4)选定CPU(越高越好)
(5)设定年代大小、升级年龄
(6)设定日志参数
-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.图形界面用在什么地方?测试,测试的时候进行监控(压测观察)
|