zoukankan      html  css  js  c++  java
  • 【JVM】调优常用参数总结

    GC通用参数

    • -Xmn:年轻代

    • -Xss:栈空间

    • -Xms:初始堆大小

    • -Xmx:最大堆大小

    • -XX:NewSize=n:设置年轻代大小

    • -XX:NewRatio=n:设置年轻代和年老代的比值。如:为3,表示年轻代与年老代比值为1:3,年轻代占整个年轻代年老代和的1/4

    • -XX:SurvivorRatio=n:年轻代中Eden区与两个Survivor区的比值。注意Survivor区有两个。如:3,表示Eden:Survivor=3:2,一个Survivor区占整个年轻代的1/5

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

  • 相关阅读:
    一、数据库概念和操作数据库的命令
    [LeetCode] 208. Implement Trie (Prefix Tree) ☆☆☆
    [LeetCode] 329. Longest Increasing Path in a Matrix ☆☆☆
    [LeetCode] 382. Linked List Random Node ☆☆☆
    Java异常之try,catch,finally,throw,throws
    C#畅谈“网络电视”
    JavaWeb项目导入MyEclipse后变为JAVA项目项目【解决方法】
    springmvc学习笔记(理论)
    Struts2之类型转换器
    Oracle笔记
  • 原文地址:https://www.cnblogs.com/zhangyibing/p/13789500.html
Copyright © 2011-2022 走看看