堆设置
-Xmx
指定 jvm 的最大 heap 大小 , 如 :-Xmx=2g
-Xms
指定 jvm 的最小 heap 大小 , 如 :-Xms=2g , 高并发应用, 建议和-Xmx 一样, 防止因为内存收缩/突然增大带来的性能影响
-Xmn
指定 jvm 中 New Generation 的大小 , 如 :-Xmn256m。 这个参数很影响性能, 如果你的程序需要比较多的临时内存, 建议设置到 512M, 如果用的少, 尽量降低这个数值, 一般来说 128/256 足以使用了。 整个堆大小=年轻代大小 + 年老代大小 + 持久代大小
-XX:PermSize=
指定 jvm 中 Perm Generation 的最小值 , 如 :-XX:PermSize=32m。 这个参数需要看你的实际情况,。 可以通过 jmap 命令看看到底需要多少。
-XX:MaxPermSize=
指定 Perm Generation 的最大值 , 如 :-XX:MaxPermSize=64m
-Xss
指定线程桟大小 , 如 :-Xss128k, 一般来说,webx 框架下的应用需要 256K。 如果你的程序有大规模的递归行为, 请考虑设置到 512K/1M。 这个需要全面的测试才能知道。 不过, 256K 已经很大了。 这个参数对性能的影响比较大的。
-XX:NewRatio=
指定 jvm 中 Old Generation heap size 与 New Generation 的比例 , 在使用 CMS GC 的情况下此参数失效 , 如 :-XX:NewRatio=2
-XX:SurvivorRatio=
指定 New Generation 中 Eden Space 与一个 Survivor Space 的 heap size 比例 ,-XX:SurvivorRatio=8, 那么在总共 New Generation 为 10m 的情况下 ,Eden Space 为 8m
-XX:MinHeapFreeRatio=
指定 jvm heap 在使用率小于 n 的情况下 ,heap 进行收缩 ,Xmx==Xms 的情况下无效 , 如 :-XX:MinHeapFreeRatio=30
收集器设置
-XX:+UseParallelGC
设指定在 New Generation 使用 parallel collector, 并行收集 , 暂停 app threads, 同时启动多个垃圾回收 thread, 不能和 CMS gc 一起使用 . 系统吨吐量优先 , 但是会有较长长时间的 app pause, 后台系统任务可以使用此 gc
-XX:ParallelGCThreads=
指定 parallel collection 时启动的 thread 个数 , 默认是物理 processor 的个数
-XX:+UseParallelOldGC
指定在 Old Generation 使用 parallel collector
-XX:+UseParNewGC
指定在 New Generation 使用 parallel collector, 是 UseParallelGC 的 gc 的升级版本 , 有更好的性能或者优点 , 可以和 CMS gc 一起使用
-XX:+CMSParallelRemarkEnabled
在使用 UseParNewGC 的情况下 , 尽量减少 mark 的时间
-XX:+UseConcMarkSweepGC
指定在 Old Generation 使用 concurrent cmark sweep gc,gc thread 和 app thread 并行 ( 在 init-mark 和 remark 时 pause app thread). app pause 时间较短 , 适合交互性强的系统 , 如 web server
-XX:+UseCMSCompactAtFullCollection
在使用 concurrent gc 的情况下 , 防止 memory fragmention, 对 live object 进行整理 , 使 memory 碎片减少
-XX:CMSInitiatingOccupancyFraction=
指示在 old generation 在使用了 n% 的比例后 , 启动 concurrent collector, 默认值是 68, 如 :-XX:CMSInitiatingOccupancyFraction=70
-XX:+UseCMSInitiatingOccupancyOnly
指示只有在 old generation 在使用了初始化的比例后 concurrent collector 启动收集
垃圾回收统计信息
-XX:+PrintGC
-XX:+PrintGCDetails
-XX:+PrintGCTimeStamps
-Xloggc:filename
把相关日志信息记录到文件以便分析。
其他
-XX:MaxTenuringThreshold=
指定一个 object 在经历了 n 次 young gc 后转移到 old generation 区 , 在 linux64 的 java6 下默认值是 15, 此参数对于 throughput collector 无效 , 如 :-XX:MaxTenuringThreshold=31
-XX:+DisableExplicitGC
禁止 Java 程序中的 full gc, 如 System.gc() 的调用. 最好加上么, 防止程序在代码里误用了。对性能造成冲击。