zhangyibing

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的堆空间占用比例

分类:

JVM JVM

技术点:

相关文章:

  • 2018-09-13
  • 2021-12-24
  • 2021-11-16
  • 2022-01-14
  • 2022-01-12
  • 2021-10-06
  • 2019-11-07
猜你喜欢
  • 2021-08-21
  • 2021-10-16
  • 2021-09-11
  • 2020-05-08
  • 2021-05-13
相关资源
相似解决方案