视频讲解地址
文章目录
- 一、开始
- 二、常用命令
- 1、原生命令
- 2、arthas命令
- 三、Parallel
- 四、G1 相关参数
- 五、通用参数
- 六、JVM调优参数
一、开始
查看当前JDK版本所支持的垃圾回收器有哪些、以及默认使用的回收器
java -XX:+PrintFlagsFinal -version | grep -E '\<Use.*GC\>'
JDK8和JDK11运行上述命令结果如下:
各种组合GC的开关
名称 | 描述 |
---|---|
UseSerialGC | 年轻代和老年代都用串行收集器 |
UseParNewGC | 年轻代使用ParNew,老年代使用 Serial Old |
UseParallelGC | 年轻代使用Paraller Scavenge,老年代使用Serial Old |
UseParallelOldGC | 新生代Paraller Scavenge,老年代使用Paraller Old |
UseConcMarkSweepGC | 表示年轻代使用ParNew,老年代的用CMS + Serial Old |
UseG1GC | 使用G1垃圾回收器 |
- JDK8 默认是 Paraller Scavenge + Paraller Old ,JDK11默认是 G1 (其实JDK9开始默认是G1)。
- 在JDK11里面没有看到 ParNew,是因为 ParNew+Serial Old 这个组合已经不存在了。
注:
- 垃圾回收器和JDK的版本是有关系的,但目前主流的版本是8和11,所以此次学习也是用这两个版本
- 8和11默认的回收器分别是UseParallelGC和G1,既如此我们就深入理解它们
- 理解垃圾回收器无非是理论+各种参数,理论上篇已经解释了,此次就来看看这两款收集器的核心配置参数
二、常用命令
1、原生命令
注:pid 可以使用 jps/jcmd 查看
命令 | 描述 | 结果 |
---|---|---|
jcmd pid VM.flags | 查看当前JVM参数 | |
jmap -heap pid | 查看当前堆信息(JDK11用不了) | |
jcmd pid GC.heap_info | 查看各个区域内存使用情况,可以看Metaspace、和class space | |
jstat -gc pid | 查看内存使用情况、且可以看到GC频率 |
注: jstat -gc 结果描述
- `S0C`: 第一个幸存区(Survivor 0)的容量(Capacity)。
- `S1C`: 第二个幸存区(Survivor 1)的容量。
- `S0U`: 第一个幸存区的使用量(Used)。
- `S1U`: 第二个幸存区的使用量。
- `EC`: Eden 区的容量。
- `EU`: Eden 区的使用量。
- `OC`: 老年代的容量。
- `OU`: 老年代的使用量。
- `MC`: 元空间(Metaspace)的容量。
- `MU`: 元空间的使用量。
- `CCSC`: 压缩类空间的容量。
- `CCSU`: 压缩类空间的使用量。
- `YGC`: 年轻代垃圾回收的次数。
- `YGCT`: 年轻代垃圾回收的总时间。
- `FGC`: 老年代垃圾回收的次数。
- `FGCT`: 老年代垃圾回收的总时间。
- `CGC`: 全局垃圾回收的次数。
- `CGCT`: 全局垃圾回收的总时间。
- `GCT`: 所有垃圾回收的总时间。
2、arthas命令
命令 | 描述 | 图视 |
---|---|---|
memory | 查看内存使用情况 |
想了解arthas的小伙伴可以看这个: java线上问题排查工具——Arthas
三、Parallel
查看某个参数的值:jinfo -flag ParallelGCThreads pid
参数 | 描述 |
---|---|
ParallelGCThreads | 设置用于垃圾回收的线程数,通常设置为处理器数量的几倍。 |
MaxGCPauseMillis | 设置期望的最大垃圾收集停顿时间,Parallel GC会尝试调整各种参数以满足这个目标。 |
GCTimeRatio | 设置垃圾收集时间占总时间的比例。值为n,表示垃圾收集时间占总时间的1/(1+n)。比如19表示垃圾收集时间占总时间的1/20。 |
UseAdaptiveSizePolicy | 当这个参数激活后,就不需要人工指定新生代的大小、Eden和Survivor区的比例、晋升老年代对象的大小,虚拟机会动态的调整。 |
四、G1 相关参数
查看某个参数的值:jinfo -flag G1HeapRegionSize pid
参数 | 描述 | 备注 |
---|---|---|
G1HeapRegionSize | 设置Region大小,并非最终值,会按照实际空间来看 | |
MaxGCPauseMillis | 设置G1收集过程目标时间,默认 200ms | |
G1NewSizePercent | 新生代最小值 | 在我这个版本JDK没有这个参数 |
G1MaxNewSizePercent | 新生代最大值,默认值60% | 在我这个版本JDK没有这个参数 |
ParallelGCThreads | STW期间,并行GC线程数 | |
ConcGCThreads | 并发标记阶段,并行执行的线程数 | |
InitiatingHeapOccupancyPercent | 设置触发标记周期的 Java 堆占用率阈值。默认值是45%。这里的java堆占比指的是non_young_capacity_bytes,包括old+humongous |
五、通用参数
参数 | 描述 |
---|---|
Xmx | 设置JVM的最大堆内存大小。 |
Xms | 设置JVM的初始堆内存大小。 |
Xmn | 设置新生代的大小。新生代包含Eden区和两个Survivor区 |
Xss | 设置每个线程的堆栈大小。 |
SurvivorRatio | 设置Eden区与Survivor区的大小比例。 |
MaxPermSize / MaxMetaspaceSize | 设置永久代(PermGen)或元空间(Metaspace)的最大大小。 |
六、JVM调优参数
所谓的JVM调优,就是为了保证我们系统的稳定运行
- 设置各个内存区域的大小和占比【五】
- 选定合适的垃圾回收器(基本都是用默认的)
- 当前系统关注的是快速回收还是吞吐量,基于此去设置 Parallel 和 G1的相关参数