GC常用参数

2021-05-27  本文已影响0人  TZX_0710

GC常用参数

• -Xmn -Xms -Xmx -Xss     // 年轻代 最小堆 最大堆 栈空间
• -XX:+UseTLAB     // 使用TLAB,默认打开
• -XX:+PrintTLAB     // 打印TLAB的使用情况
• -XX:TLABSize // 设置TLAB大小
• -XX:+DisableExplictGC // System.gc()不管用 ,FGC
• -XX:+PrintGC  // 打印GC日志
• -XX:+PrintGCDetails    // 打印GC日志详情
• -XX:+PrintHeapAtGC    // 每一次GC后都打印堆信息
• -XX:+PrintGCTimeStamps    // 打印GC时间戳
• -XX:+PrintGCApplicationConcurrentTime     // (低)打印应用程序时间
• -XX:+PrintGCApplicationStoppedTime     //(低)打印暂停时长
• -XX:+PrintReferenceGC (重要性低)记录回收了多少种不同引用类型的引用
• -verbose:class     // 类加载详细过程
• -XX:+PrintVMOptions    // 打印VM
• -XX:+PrintFlagsFinal    //  输出所有 XX 参数的值
•  -XX:+PrintFlagsInitial // 查看所有 XX 参数的默认值
• -Xloggc:opt/log/gc.log    // 打印gc日志到文件
• -XX:MaxTenuringThreshold     // 升代年龄,最大值15
• -XX:PreBlockSpin     // 控制多线程自旋锁优化的自旋次数

Parallel常用参数

• -XX:SurvivorRatio    // Eden与Survivor的占用比例。例如8表示,一个survivor区占用 1/8 的Eden内存,即1/10的新生代内存
• -XX:PreTenureSizeThreshold     // 大对象到底多大
• -XX:MaxTenuringThreshold    // 设置对象在新生代中最大的存活次数,最大值15,并行回收机制默认为15,CMS默认为4
• -XX:+ParallelGCThreads     // 并行收集器的线程数,同样适用于CMS,一般设为和CPU核数相同
• -XX:+UseAdaptiveSizePolicy     // 自动选择各区大小比例

CMS常用参数

• -XX:+UseConcMarkSweepGC    // 使用CMS收集器收集老年代
• -XX:ParallelCMSThreads     // CMS线程数量
• -XX:CMSInitiatingOccupancyFraction     // 使用多少比例的老年代后开始CMS收集,默认是68%(近似值),如果频繁发生SerialOld卡顿,应该调小,(频繁CMS回收)
• -XX:+UseCMSCompactAtFullCollection     // 在FGC时进行压缩
• -XX:CMSFullGCsBeforeCompaction     // 多少次FGC之后进行压缩
• -XX:+CMSClassUnloadingEnabled    // 老年代启用CMS,但默认是不会回收永久代(Perm)的。此处对Perm区启用类回收,防止Perm区内存满。(需要与+CMSPermGenSweepingEnabled同时启用)
• -XX:CMSInitiatingPermOccupancyFraction     // 达到什么比例时进行Perm回收
• -XX:GCTimeRatio     // 设置GC时间占用程序运行时间的百分比
• -XX:MaxGCPauseMillis     // 停顿时间,是一个建议时间,GC会尝试用各种手段达到这个时间,比如减小年轻代
上一篇下一篇

猜你喜欢

热点阅读