由于大部分对象第一次分配内存空间都会由New区域存放,大小仅为64M的New区域非常容易被塞满对象,所以导致频繁执行New区域的局部GC,虽然这种局部GC比Full GC执行要快很多,但过于频繁的执行也严重的影响到了性能。另外,这也导致了大量的Old区域空间长期处于闲置状态,很少获得使用的机会。最后观察对JVM中占据1984M的Old区域使用效率的检测,发现1984M Old区域堆内存基本上从来没有使用过。
造成问题的原因: 当前配置的JVM启动参数虽然未直接指定New区域和Old区域的分配比例(默认是1:2),但由于配置了“-XX:+UseConcMarkSweepGC”等参数导致默认1:2比例失效,此时又没有显示去指定New区域大小,造成了New区域和Old区域的比例被修改变成了最小值1:15。所以New区域的大小才仅仅为2G×1/(1+15)=64M。
解决办法:修改启动参数可在如下两处任意一处操作即可:
修改各个 DOMAIN_HOME
/config/config.xml中各个Server的server-start->arguments内容。
修改各个Admin Console界面->Servers->选中要修改的Server -> Configuration->Server Start->Arguments。