background image

-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= 进行设置。