-XX:+UseSerialGC |
使用单线程垃圾回收算法 |
适用于容量小于100MB的堆 |
-XX:+UseParallelOldGC |
应用线程停顿时使用多线程对老年代进行垃圾回收 |
如果你的应用能够容忍偶尔发生长时间停顿,而你又希望用最小的CPU消耗取得最大吞吐量,可以考虑使用这个参数 |
-XX:+UseParallelGC |
应用线程停顿时使用多线程对新生代进行垃圾回收 |
|
-XX:+UseConcMarkSweepGC |
使用后台线程以最低停顿时间回收老年代垃圾对象 |
如果你有充足的CPU资源可以运行后台线程,你的堆也相对较小,并且你不希望垃圾收集的停顿时间过长,可以考虑使用这个参数 |
-XX:+UseParNewGC |
应用线程停顿时使用多线程对新生代进行垃圾回收 |
与ConcMarkSweepGC标志结合使用 |
-XX:+UseG1GC |
应用线程停顿时使用多线程对新生代进行垃圾回收,使用后台线程对老年代进行垃圾回收,以最大程度减少停顿 |
如果你有足够的CPU资源可以运行后台线程,你的堆也比较大,同时你又不希望有长时间的停顿,可以考虑使用这个参数 |
-Xms |
指定堆的初始大小 |
|
-Xmx |
指定堆的最大值 |
|
-XX:NewRatio |
指定新生代与老年代之间的比例 |
|
-XX:NewSize |
指定新生代的初始大小 |
|
-XX:MaxNewSize |
指定新生代的最大值 |
|
-Xmn |
指定新生代的初始值最大值 |
|
-XX:PermSize=N |
指定永久代的初始值 |
|
-XX:MaxPermSize=N |
指定永久代的最大值 |
|
-XX:MetaspaceSize=N |
指定元空间的初始大小 |
|
-XX:MaxMetaspaceSize=N |
指定云空间的最大容量 |
|
-XX:ParallelGCThreads=N |
指定垃圾收集使用的线程数 |
如果系统上同时运行了多个JVM,可以适当减少该值。如果堆空间非常大且CPU资源充足可以适当增大该值 |
-verbose:gc |
开启基本GC日志 |
建议一直开启 |
-Xloggc:<path> |
指定GC日志输出文件路径 |
|
-XX:+PrintGC |
开启基本GC日志 |
建议一直开启 |
-XX:+PrintGCDetails |
开启详细GC日志 |
|
-XX:+PrintGCTimeStamps |
为GC日志中的每个条目打印时间戳 |
|
-XX:+PrintGCDateStamps |
为GC日志中的每个条目打印日期时间戳 |
|
-XX:+PrintReferenceGC |
打印GC过程中的软引用和弱引用信息 |
如果程序中有使用软引用或弱引用,建议使用这个参数 |
-XX:+UseGCLogFileRotation |
开启GC日志循环,以节省空间 |
长期运行的程序建议使用这个参数 |
-XX:NumberOfGCLogFiles=N |
开启GC日志循环时,保留多少个日志文件 |
|
-XX:GCLogFileSize=N |
开启GC日志循环时,指定每个文件的大小 |
|
-XX:+UseAdaptiveSizePolicy |
使JVM根据GC目标调整堆大小 |
|
-XX:+PrintAdaptiveSizePolicy |
在GC日志中输出大小调整的详细信息 |
|
-XX:+PrintTenuringDistribution |
在GC日志中输出对象保持的信息 |
|
-XX:InitialSurvivorRatio=N |
设置新生代中预留给Survivor空间的大小 |
|
-XX:MinSurvivorRatio=N |
设置新生代空间中用于自适应调整Survivor空间大小 |
|
-XX:TargetSurvivorRatio=N |
设置Survivor空间保留的空闲空间 |
|
-XX:InitialTenuringThreshold=N |
JVM试图在Survivor空间保持对象的GC周期 |
|
-XX:MaxTenuringThreshold=N |
设置JVM可以将一个对象保持在Survivor空间的最大GC周期数 |
|
-XX:MaxGCPauseMillis |
为多线程垃圾收集器设置最长停顿时间,堆的大小会依据该目标动态调整 |
|
-XX:GCTimeRatio=N |
为多线程垃圾收集器设置在垃圾收集上花费的时间比例 |
|
-XX:CMSInitiatingOccupancyFraction=N |
设置CMS垃圾收集器开启老年代后台扫描的时机 |
如果发生并发失效,应该适当减少该参数的值 |
-XX:+UseCMSInitiatingOccupancyOnly |
通知CMS收集器仅通过-XX:CMSInitiatingOccupancyFraction标志决定何时启动后台扫描 |
与-XX:CMSInitiatingOccupancyFraction一起使用 |
-XX:ConcGCThreads=N |
设置CMS收集器后台扫描线程数 |
如果发生并发失效,同时又有大量的空闲CPU资源时,可以适当提高该值 |
-XX:+CMSPermGenSweepingEnabled |
通知CMS收集器对永久代进行整理 |
|
-XX:CMSInitiatingPermOccupancyFraction=N |
设置CMS开启永久代扫描的时机 |
|
-XX:+CMSClassUnloadingEnabled |
设置CMS收集器在永久代扫描结束后卸载类 |
|
-XX:CMSIncrementalMode |
设置CMS以增量模式运行 |
|
-XX:CMSIncrementalModeSafetyFactor=N |
影响增量式CMS垃圾收集后台线程的运行频度 |
|
-XX:CMSIncrementalDutyCycleMin=N |
影响增量式CMS垃圾收集后台线程的运行频度 |
|
-XX:CMSIncrementalDutyCycleMax=N |
影响增量式CMS垃圾收集后台线程的运行频度 |
|
-XX:+CMSIncrementalDutyCycle |
影响增量式CMS垃圾收集后台线程的运行频度 |
|
-XX:InitiatingHeapOccupancyPerent |
设置G1收集开启后台扫描的时机 |
如果发生并发失败应该适当减小该参数 |
-XX:G1MaxedGCCountTarget=N |
设置混合GC次数 |
|
-XX:G1HeapRegionSize=N |
设置G1分区的大小 |
|
-XX:HeapDumpOnOutOfMemoryError |
JVM堆转储 |
|
-XX:HeapDumpPath=<Path> |
设置自动堆转储的文件名 |
-XX:SoftRefLRUPolicyMSPerMB=N |
设置使用多长时间后软引用对象可以被回收 |
内存不足的情况下,减少这个值可以更快的回收软引用对象 |
-XX:MaxDirectMemorySize=N |
设置本地内存最大值 |
|
-XX:+UseLargePages |
设置JVM从操作系统的大页面系统中分配页面 |
如果操作系统支持,这个参数可以改善性能 |