GC通用参数
-
-Xmn -Xms -Xmx -Xss
年轻代 最小堆 最大堆 栈空间
-
-XX:+UseTLAB
使用TLAB,默认打开
-
-XX:+PrintTLAB
打印TLAB的使用情况
-
-XX:TLABSize
设置TLAB大小(一般不建议改动)
-
-XX:+DisableExplictGC
线上环境一定要打开,避免写System.gc(),开启的话手动gc就不管用 ,FGC
-
-XX:+PrintGC
开启打印GC日志
-
-XX:+PrintGCDetails
打印GC详细信息
-
-XX:+PrintHeapAtGC
打印在发生GC时候的堆信息
-
-XX:+PrintGCTimeStamps
打印GC的时间
-
-XX:+PrintGCApplicationConcurrentTime
(重要性低) 打印应用程序时间
-
-XX:+PrintGCApplicationStoppedTime
(重要性低) 打印暂停时长
-
-XX:+PrintReferenceGC
(重要性低) 记录回收了多少种不同引用类型的引用
-
-verbose:class
类加载详细过程
-
-XX:+PrintVMOptions
打印JVM详细参数
-
-XX:+PrintFlagsFinal -XX:+PrintFlagsInitial
必须会用,java -XX:+PrintFlagsFinal -version | grep G1
-
-Xloggc:opt/log/gc.log
-
-XX:MaxTenuringThreshold
设置升代年龄,最大值15
-
-XX:PreBlockSpin
锁自旋次数 ,热点代码检测参数
-
-XX:CompileThreshold
逃逸分析 标量替换 … 这些不建议设置
Parallel常用参数
-
-XX:SurvivorRatio
新生代中Eden区域和Survivor区域(From幸存区或To幸存区)的比例,默认为8
-
-XX:PreTenureSizeThreshold
大对象到底多大
-
-XX:MaxTenuringThreshold
进入老年代的年龄阈值,默认15(对象被复制的次数)
-
-XX:+ParallelGCThreads
并行收集器的线程数,同样适用于CMS,一般设为和CPU核数相同
-
-XX:+UseAdaptiveSizePolicy
自动选择各区大小比例
CMS常用参数
-
-XX:+UseConcMarkSweepGC
开启CMS垃圾回收
-
-XX:ParallelCMSThreads
设置CMS线程数量,一般为CPU核数的一半,CMS线程是在老年代,要留一些CPU给用户线程
-
-XX:CMSInitiatingOccupancyFraction
使用多少比例的老年代后开始CMS收集,默认是68%(近似值),如果频繁发生SerialOld卡顿,应该调小,(频繁CMS回收)
-
-XX:+UseCMSCompactAtFullCollection
在FGC时进行压缩
-
-XX:CMSFullGCsBeforeCompaction
多少次FGC之后进行压缩
-
-XX:+CMSClassUnloadingEnabled
-
-XX:CMSInitiatingPermOccupancyFraction
达到什么比例时进行Perm回收
-
GCTimeRatio
设置GC时间占用程序运行时间的百分比
-
-XX:MaxGCPauseMillis
停顿时间,是一个建议时间,GC会尝试用各种手段达到这个时间,比如减小年轻代
G1常用参数
-
-XX:+UseG1GC
开启G1垃圾回收
-
-XX:MaxGCPauseMillis
建议值,G1会尝试调整Young区的块数来达到这个值
-
-XX:+G1HeapRegionSize
分区大小,建议逐渐增大该值,1 2 4 8 16 32。 随着size增加,垃圾的存活时间更长,GC间隔更长,但每次GC的时间也会更长 ZGC做了改进(动态区块大小)
-
G1NewSizePercent
新生代最小比例,默认为5%
-
G1MaxNewSizePercent
新生代最大比例,默认为60%
-
GCTimeRatio
GC时间建议比例,G1会根据这个值调整堆空间
-
ConcGCThreads
线程数量
-
InitiatingHeapOccupancyPercent
启动G1的堆空间占用比例