原文转载: https://yq.aliyun.com/articles/691713
常见配置汇总
堆设置
-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:MaxPermSize=n:设置持久代大小
收集器设置
-XX:+UseSerialGC:设置串行收集器
-XX:+UseParallelGC:设置并行收集器
-XX:+UseParalledlOldGC:设置并行年老代收集器
-XX:+UseConcMarkSweepGC:设置并发收集器
垃圾回收统计信息
-XX:+PrintGC
-XX:+PrintGCDetails
-XX:+PrintGCTimeStamps
-Xloggc:filename
并行收集器设置
-XX:ParallelGCThreads=n:设置并行收集器收集时使用的CPU数。并行收集线程数。
-XX:MaxGCPauseMillis=n:设置并行收集最大暂停时间
-XX:GCTimeRatio=n:设置垃圾回收时间占程序运行时间的百分比。公式为1/(1+n)
并发收集器设置
-XX:+CMSIncrementalMode:设置为增量模式。适用于单CPU情况。
-XX:ParallelGCThreads=n:设置并发收集器年轻代收集方式为并行收集时,使用的CPU数。并行收集线程数。
辅助信息
JVM提供了大量命令行参数,打印信息,供调试使用。主要有以下一些:
-XX:+PrintGC:输出形式:[GC 118250K->113543K(130112K), 0.0094143 secs] [Full GC 121376K->10414K(130112K), 0.0650971 secs]
-XX:+PrintGCDetails:输出形式:[GC [DefNew: 8614K->781K(9088K), 0.0123035 secs] 118250K->113543K(130112K), 0.0124633 secs] [GC [DefNew: 8614K->8614K(9088K), 0.0000665 secs][Tenured: 112761K->10414K(121024K), 0.0433488 secs] 121376K->10414K(130112K), 0.0436268 secs]
-XX:+PrintGCTimeStamps -XX:+PrintGC:PrintGCTimeStamps可与上面两个混合使用
输出形式:11.851: [GC 98328K->93620K(130112K), 0.0082960 secs]
-XX:+PrintGCApplicationConcurrentTime:打印每次垃圾回收前,程序未中断的执行时间。可与上面混合使用。输出形式:Application time: 0.5291524 seconds
-XX:+PrintGCApplicationStoppedTime:打印垃圾回收期间程序暂停的时间。可与上面混合使用。输出形式:Total time for which application threads were stopped: 0.0468229 seconds
-XX:PrintHeapAtGC: 打印GC前后的详细堆栈信息。
-Xloggc:filename:与上面几个配合使用,把相关日志信息记录到文件以便分析。
JVM参数配置 | |
-server | C2引擎执行 |
-Xms20g | 最小堆内存20G |
-Xmx20g | 最大堆内存20G |
-Xmn8g | 新生代8G |
-XX:PermSize=256m | Perm大小256MB |
-XX:MaxPermSize=256m | Perm大小256MB |
-XX:SurvivorRatio=10 | YoungGC 3个区的比例 |
-XX:+UseConcMarkSweepGC | Old区使用CMS GC |
-XX:+UseCMSCompactAtFullCollection | 一旦触发FullGC对Old区进行压缩减少内存碎片 |
-XX:CMSMaxAbortablePrecleanTime=5000 | CMS GC的回收超时时间,避免GC时间太久 |
-XX:+CMSClassUnloadingEnabled | 支持CMS GC时对Perm区的Class和ClassLoader做GC,否则要等FullGC |
-XX:CMSInitiatingOccupancyFraction=80 | Old区达到80%时触发CMS GC,如果不设置,JVM会自适应,效果不好 |
-XX:+UseCMSInitiatingOccupancyOnly | 只以CMSInitiatingOccupancyFraction设定的阈值为准,不加这个参数CMSInitiatingOccupancyFraction会不生效 |
-XX:+HeapDumpOnOutOfMemoryError | OOM时自动jmap dump内存 |
-XX:HeapDumpPath= | OOM时dump内存的位置 |
-Xloggc: | GC log位置 |
-XX:+PrintGCDetails | 打印GC详细信息 |
-XX:+PrintGCDateStamps | 将GC时间由时间戳改为人类可识别的时刻点 |
-Dsun.net.client.defaultConnectTimeout=10000 | socket连接超时时间 |
-Dsun.net.client.defaultReadTimeout=30000 | socket读超时时间 |
-verbose:class | 打印类加载信息 |
-XX:MaxDirectMemorySize=1g | 控制DirectByteBuffer占用的堆外内存大小,防止堆外内存导致OOM |
-XX:+ExplicitGCInvokesConcurrent | 调用System.gc()时触发CMS GC而不是Full GC |
-XX:ParallelGCThreads=${CPU_COUNT} | 并发GC线程数(Young GC) |
-Dfile.encoding=${JAVA_FILE_ENCODING} | 文件默认编码 |