一个可以参考的JVM内存分配

下面是java命令有关JVM内存分配的参数

JAVA_MEM_OPTS=""
BITS=`java -version >& | grep -i -bit`
if [ -n "$BITS" ]; then
JAVA_MEM_OPTS=" -server -Xmx2g -Xms2g -Xmn256m -XX:PermSize=128m -Xss256k -XX:+DisableExplicitGC -XX:+UseConcMarkSweepGC -XX:+CMSParallelRemarkEnabled -XX:+UseCMSCompactAtFullCollection -XX:LargePageSizeInBytes=128m -XX:+UseFastAccessorMethods -XX:+UseCMSInitiatingOccupancyOnly -XX:CMSInitiatingOccupancyFraction=70 "
else
JAVA_MEM_OPTS=" -server -Xms1g -Xmx1g -XX:PermSize=128m -XX:SurvivorRatio=2 -XX:+UseParallelGC "
fi

1、64位 Server VM:

 参数  参数说明
-server 服务器模式
-Xmx2g JVM最大的堆内存大小为2G。Xmx默认为物理内存的1/4但小于1G
-Xms2g JVM启动初始化堆大小为2G,Xms的默认是物理内存的1/64但小于1G。Xms等于Xmx,好处是避免每次gc后,调整堆的大小,减少系统内存分配开销
-Xmn256m JVM堆中的新生代大小为256M
-XX:PermSize=128m JVM持久代的初始化大小为128M
-Xss256k 每个线程的栈大小为256k
-XX:+DisableExplicitGC 这个将会忽略手动调用GC的代码,使得 System.gc()的调用就会变成一个空调用,完全不会触发任何GC。
-XX:+UseConcMarkSweepGC 开启此参数使用ParNew & CMS(serial old为替补)搜集器。如果配置了CMS GC的方式,那么新生代默认采取的就是ParNew GC的方式
-XX:+CMSParallelRemarkEnabled 降低标记停顿
-XX:+UseCMSCompactAtFullCollection 在FULL GC的时候压缩内存。CMS是不会移动内存的,因此这个非常容易产生碎片导致内存不够用,因此内存的压缩这个时候就会被启用。 增加这个参数是个好习惯。 
-XX:LargePageSizeInBytes=128m 内存页的大小, 不可设置过大, 会影响Perm的大小。 
-XX:+UseFastAccessorMethods 快速调用成员方法。什么方法叫做AccessorMethods,①必须是成员方法,静态方法不行,②返回值类型必须是引用类型或者int,其它都不算,③方法体的代码必须满足aload_0; getfield #index; areturn或ireturn这样的模式,方法名是什么都没关系,是不是get、is、has开头都不重要。 因为此类方法方法体很简单,而且没有方法计数器,开启此设置后可以跳过对该类方法的编译。该设置默认在jdk6中是开启的,但由于jdk7的server模式默认开启了多层编译,此时在这种多台方法调用时甚至会导致性能下降,jdk7好像是默认关闭的。
-XX:+UseCMSInitiatingOccupancyOnly  命令JVM不基于运行时收集的数据来启动CMS垃圾收集周期。而是,当该标志被开启时,JVM通过CMSInitiatingOccupancyFraction的值进行每一次CMS收集,而不仅仅是第一次。然而,请记住大多数情况下,JVM比我们自己能作出更好的垃圾收集决策。因此,只有当我们充足的理由(比如测试)并且对应用程序产生的对象的生命周期有深刻的认知时,才应该使用该标志。
-XX:CMSInitiatingOccupancyFraction=70  当堆满之后,并行收集器便开始进行垃圾收集,例如,当没有足够的空间来容纳新分配或提升的对象。对于CMS收集器,长时间等待是不可取的,因为在并发垃圾收集期间应用持续在运行(并且分配对象)。因此,为了在应用程序使用完内存之前完成垃圾收集周期,CMS收集器要比并行收集器更先启动。因为不同的应用会有不同对象分配模式,JVM会收集实际的对象分配(和释放)的运行时数据,并且分析这些数据,来决定什么时候启动一次CMS垃圾收集周期。为了引导这一过程, JVM会在一开始执行CMS周期前作一些线索查找。该线索由-XX:CMSInitiatingOccupancyFraction=<value>来设置,该值代表老年代堆空间的使用率。比如,value=75意味着第一次CMS垃圾收集会在老年代被占用75%时被触发。通常CMSInitiatingOccupancyFraction的默认值为68(之前很长时间的经历来决定的)。

2、32位 Server VM

可以参考上表,指标的值有所不同。

3、关于Partial GC和Full GC

Partial GC:并不收集整个GC堆的模式
Young GC:只收集新生代的GC,比如收集器:ParNew
Old GC:只收集老年代的GC,比如收集器:CMS
Mixed GC:收集整个新生代以及部分老年代的GC,只有G1有这个模式

Full GC:收集整个堆
包括新生代、老年代、持久代(如果存在的话)等所有部分的模式。

上一篇:servlet二


下一篇:java后端书籍推荐