-Xmx5g:设置 JVM 最大可用内存为 5G
。
-Xms5g:设置 JVM 初始内存为 5G。此值可以设置与-Xmx 相同,以避免每次垃圾回收
完成后 JVM
重新分配内存。
-Xmn2g:设置年轻代大小为 2G
。整个堆内存大小 =
年轻代大小 +
年老代大小 + 持
久代大小 。持久代一般固定大小为 64m,所以增大年轻代后,将会减小年老代大小。
此值对系统性能影响较大,Sun 官方推荐配置为整个堆的 3/8
。
-XX:+UseParNewGC:设置年轻代为并行收集。可与 CMS 收集同时使用。JDK5.0 以
上,JVM
会根据系统配置自行设置,所以无需再设置此值。
-XX:ParallelGCThreads=8:配置并行收集器的线程数,即:同时多少个线程一起进行
垃圾回收。此值最好配置与处理器数目相等。
-XX:SurvivorRatio=6:设置年轻代中 Eden 区与 Survivor 区的大小比值。根据经验设
置为 6,则两个 Survivor 区与一个 Eden 区的比值为 2:6,一个 Survivor 区占整个年轻
代的 1/8
。
-XX:MaxTenuringThreshold=30:设置垃圾最大年龄(次数)。如果设置为 0 的话,
则年轻代对象不经过 Survivor 区直接进入年老代。对于年老代比较多的应用,可以提高
效率。如果将此值设置为一个较大值,则年轻代对象会在 Survivor 区进行多次复制,这
样可以增加对象再年轻代的存活时间,增加在年轻代即被回收的概率。设置为 30 表示一
个对象如果在 Survivor 空间移动 30
次还没有被回收就放入年老代。
-XX:+UseConcMarkSweepGC:设置年老代为并发收集。测试配置这个参数以后,参
数-XX:NewRatio=4 就失效了,所以,此时年轻代大小最好用-Xmn 设置,因此这个参
数不建议使用。
参考资料 - JVM 堆内存的分代
虚 拟 机 的 堆 内 存 共 划 分 为 三 个 代 : 年 轻 代 ( Young Generation) 、年 老代 ( Old
Generation)和持久代(Permanent Generation)。其中持久代主要存放的是 Java
类的类信息,与垃圾收集器要收集的 Java 对象关系不大。所以,年轻代和年老代的划分
才是对垃圾收集影响比较大的。
年轻代
所有新生成的对象首先都是放在年轻代的。年轻代的目标就是尽可能快速的收集掉那些
生命周期短的对象。年轻代分三个区。一个 Eden
区,两个 Survivor 区(一般而言)。
大部分对象在 Eden 区中生成。当 Eden 区满时,还存活的对象将被复制到 Survivor 区
(两个中的一个),当一个 Survivor 区满时,此区的存活对象将被复制到另外一个
Survivor 区,当另一个 Survivor 区也满了的时候,从前一个 Survivor 区复制过来的并
“
且此时还存活的对象,将被复制 年老区(Tenured)”。
需要注意,两个 Survivor 区是对称的,没先后关系,所以同一个 Survivor 区中可能同
时存在从 Eden 区复制过来对象,和从另一个 Survivor 区复制过来的对象;而复制到年
老区的只有从前一个 Survivor 区(相对的)过来的对象。而且,Survivor 区总有一个
是空的。特殊的情况下,根据程序需要,Survivor 区是可以配置为多个的(多于两个),
这样可以增加对象在年轻代中的存在时间,减少被放到年老代的可能。
年老代
在年轻代中经历了 N(可配置)次垃圾回收后仍然存活的对象,就会被放到年老代中。
因此,可以认为年老代中存放的都是一些生命周期较长的对象。
持久代
用于存放静态数据,如 Java Class, Method 等。持久代对垃圾回收没有显著影响,但
是有些应用可能动态生成或者调用一些 Class
,例如 Hibernate 等,在这种时候需要设
置一个比较大的持久代空间来存放这些运行过程中动态增加的类型。持久代大小通过
-XX:MaxPermSize= 进行设置。