GC 常用参数
-Xmn -Xms -Xmx –Xss 年轻代 最小堆 最大堆 栈空间
-XX:+UseTLAB -XX:+PrintTLAB -XX:TLABSize | 使用 TLAB, 默认打开 打印 TLAB 的使用情况 设置 TLAB 大小 |
-XX:+DisableExplicitGC | 启用用于禁用对的调用处理的选项 System.gc() |
-XX:+PrintGC | 查看 GC 基本信息 |
-XX:+PrintGCDetails -XX:+PrintHeapAtGC | 查看 GC 详细信息 每次一次 GC 后, 都打印堆信息 启用在每个 GC 上打印时间戳的功能 |
-XX:+PrintGCTimeStamps | |
-XX:+PrintGCApplicationConcurrentTime 打印应用程序时间(低) | |
-XX:+PrintGCApplicationStoppedTime | 打印暂停时长(低) |
-XX:+PrintReferenceGC | 记录回收了多少种不同引用类型的引用(重要性低) |
-verbose:class | 类加载详细过程 |
-XX:+PrintVMOptions 可在程序运行时, 打印虚拟机接受到的命令行显示参数
-XX:+PrintFlagsFinal -XX:+PrintFlagsInitial 打印所有的 JVM 参数、 查看所有 JVM 参数启动的初始值(必须会用)
-XX:MaxTenuringThreshold 升代年龄, 最大值 15, 并行(吞吐量) 收集器的默认值为 15, 而 CMS 收集器的默认值为 6
Parallel 常用参数
-XX:SurvivorRatio -XX:PreTenureSizeThreshold | 设置伊甸园空间大小与幸存者空间大小之间的比率。 默认情况下, 此选项设置为 8 大对象到底多大, 大于这个值的参数直接在老年代分配 |
-XX:MaxTenuringThreshold 升代年龄, 最大值 15, 并行(吞吐量) 收集器的默认值为 15, 而 CMS 收集器的默认值为 6。 | |
-XX:+ParallelGCThreads -XX:+UseAdaptiveSizePolicy | 并行收集器的线程数, 同样适用于 CMS, 一般设为和 CPU 核数相同 自动选择各区大小比例 |
CMS 常用参数
-XX:+UseConcMarkSweepGC -XX:+ParallelGCThreads | 启用 CMS 垃圾回收器 并行收集器的线程数, 同样适用于 CMS, 一般设为和 CPU 核数相同 |
-XX:CMSInitiatingOccupancyFraction 收) -XX:+UseCMSCompactAtFullCollection -XX:CMSFullGCsBeforeCompaction -XX:+CMSClassUnloadingEnabled -XX:CMSInitiatingPermOccupancyFraction | 使用多少比例的老年代后开始 CMS 收集, 默认是 68%(近似值), 如果频繁发生 SerialOld 卡顿, 应该调小, (频繁 CMS 回 |
在 FGC 时进行压缩 多少次 FGC 之后进行压缩 使用并发标记扫描(CMS) 垃圾收集器时, 启用类卸载。 默认情况下启用此选项。 达到什么比例时进行 Perm 回收, JDK 8 中不推荐使用此选项, 不能替代。 |
-XX:GCTimeRatio -XX:MaxGCPauseMillis | 设置 GC 时间占用程序运行时间的百分比(不推荐使用) 停顿时间, 是一个建议时间, GC 会尝试用各种手段达到这个时间, 比如减小年轻代 |
G1 常用参数
-XX:+UseG1GC -XX:MaxGCPauseMillis | 启用 CMS 垃圾收集器 设置最大 GC 暂停时间的目标(以毫秒为单位) 。 这是一个软目标, 并且 JVM 将尽最大的努力(G1 会尝试调整 Young 区的块数来) 来实 |
现它。 默认情况下, 没有最大暂停时间值。 | |
-XX:GCPauseIntervalMillis -XX:+G1HeapRegionSize -XX:G1NewSizePercent -XX:G1MaxNewSizePercent -XX:GCTimeRatioGC -XX:ConcGCThreads | GC 的间隔时间 分区大小, 建议逐渐增大该值, 1 2 4 8 16 32。 随着 size 增加, 垃圾的存活时间更长, GC 间隔更长, 但每次 GC 的时间也会更长 新生代最小比例, 默认为 5% 新生代最大比例, 默认为 60% 时间建议比例, G1 会根据这个值调整堆空间 线程数量 |
-XX:InitiatingHeapOccupancyPercent | 启动 G1 的堆空间占用比例, 根据整个堆的占用而触发并发 GC 周期 |