原文转载: 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} | 文件默认编码 |
本文深入解析JVM的各种关键参数配置,包括堆设置、收集器设置、垃圾回收统计信息及并行收集器设置等内容,帮助读者理解如何优化Java应用程序的性能。
9万+

被折叠的 条评论
为什么被折叠?



