理解Java虚拟机(十一)垃圾收集器常用参数总结
作者:互联网
对虚拟机非稳定的运行参数进行总结。
参数 | 描述 |
---|---|
UseSerialGC | 虚拟机运行在Client模式下的默认值,打开此开关后,使用Serial+Serial Old的手机器组合进行内存回收 |
UseParNewGC | 打开此开关之后,使用ParNew+Serial Old的收集器组合进行内存回收,在JDK 9 后不再支持 |
UseConcMarkSweepGC | 打开此开关之后,使用ParNew+CMS+Serial Old的收集器组合进行内存回收。Serial Old收集器将作为CMS收集器出现“Concurrent Mode Failure” 失败后的后背收集器使用 |
UseParallelGC | JDK9之前虚拟机在server模式下的默认值,打开此开关之后,使用Parallel Scavenge+Serial Old的收集器组合进行内存回收。 |
UseParallelOldGC | 打开此开关之后,使用Parallel Scavenge+Parallel Old的收集器组合进行内存回收 SurvivorRatio 新生代中Eden区域与Servivor区域的容量比值,默认为8,代表Eden:Survivor=8:1 |
PretenureSizeThreshold | 直接晋升到老年代的对象大小,设置此参数后,大于这个参数的对象将直接在老年代中分配 |
MaxTenuringThreshold | 晋升到老年代的对象年龄,每个对象在坚持过一次Minor GC之后,年龄加1,当超过这个参数的时候,将进入到老年代 |
UseAdaptiveSizePolicy | 动态调整java堆中各个区域的大小以及进入老年代的年龄 |
HandlePromotionFailure | 是否允许分配担保失败,即老年代的剩余空间不足以应付新生代的整个Eden和Survivor区的所有对象都存活的极端情况 |
ParallelGCThreads | 设置并行GC进行内存回收的线程数 |
GCTimeRatio | GC时间占总时间的比率,默认值为99,及1%的GC时间,仅在使用Parallel Scavenge收集器时生效 |
MaxGCPauseMillis | 设置GC的最大停顿时间,仅在使用Parallel Scavenge收集器时生效 |
CMSInitiatingOccupancyFraction | 设置CMS收集器在老年代被使用多少后出发垃圾收集器,默认值为68%,仅在使用CMS收集器的时候才能生效 |
UseCMSCompactAtFullCollection | 设置CMS收集器在完成垃圾集合后是否要进行一次内存碎片整理,仅在使用CMS收集器时生效,此参数从JDK9开始废弃 |
CMSFullGCsBeforeCompaction | 设置CMS收集器在进行若干次垃圾收集后在启动一次内存碎片整理。仅在使用CMS手机时才会生效,此参数从JDK9开始废弃 |
UserG1GC | 使用G1收集器,这个是JDK9后的Server模式默认值 |
G1HeapRegionSinze=n | 设置Region大小,并非最终值 |
MaxGCPauseMillis | 设置G1收集过程目标时间,默认值是200ms,不是硬性条件 |
G1NewSizePercent | 新生代最小值,默认值是5% |
G1MaxNewSizePercent | 新生代最大值,默认值是60% |
ParallelGCThreads | 用户线程冻结期间并行执行的收集器线程数 |
ConcGCThreads=n | 并发标记、并发整理的执行线程数,对不同的收集器,根据其能够并发的阶段,有不同的含义 |
InitiationHeadOccupancyPercent | 设置触发标记周期的Java堆占用率阈值。默认值是45%。这里的java堆占比指的是non_yong_capacity_bytes,包括old + humongous |
UserShenandoahGC | 使用Shenandoah收集器。这个选项在OracleJDK中不被支持,只能在OpenJDK12或者某些支持Shenandoah的Backport发行版本使用。目前仍然要配合 -XX:+UnlockExperimentalVMOptions使用 |
ShenandoahGCHeuristics | Shenandoah何时启动一次GC过程,其可选值有adaptive、static、compact、passive、aggressive |
UseZGC | 使用ZGC收集器,目前仍然要配合 -XX:+UnlockExperimentalVMOptions使用 |
UseNUMA | 启动NUMA内存分配支持,目前只有Parallel和ZGC支持,以后G1收集器可能也会支持该选项 |
标签:Java,收集器,虚拟机,内存,使用,默认值,CMS,Parallel 来源: https://blog.csdn.net/JinYJ2014/article/details/122692318