编程语言
首页 > 编程语言> > 理解Java虚拟机(十一)垃圾收集器常用参数总结

理解Java虚拟机(十一)垃圾收集器常用参数总结

作者:互联网

对虚拟机非稳定的运行参数进行总结。

参数描述
UseSerialGC虚拟机运行在Client模式下的默认值,打开此开关后,使用Serial+Serial Old的手机器组合进行内存回收
UseParNewGC打开此开关之后,使用ParNew+Serial Old的收集器组合进行内存回收,在JDK 9 后不再支持
UseConcMarkSweepGC打开此开关之后,使用ParNew+CMS+Serial Old的收集器组合进行内存回收。Serial Old收集器将作为CMS收集器出现“Concurrent Mode Failure” 失败后的后背收集器使用
UseParallelGCJDK9之前虚拟机在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进行内存回收的线程数
GCTimeRatioGC时间占总时间的比率,默认值为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使用
ShenandoahGCHeuristicsShenandoah何时启动一次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