[原创]局部GC问题的解决_Tomcat, WebLogic及J2EE讨论区_Weblogic技术|Tuxedo技术|中间件技术|Oracle论坛|JAVA论坛|Linux/Unix技术|hadoop论坛_联动北方技术论坛  
网站首页 | 关于我们 | 服务中心 | 经验交流 | 公司荣誉 | 成功案例 | 合作伙伴 | 联系我们 |
联动北方-国内领先的云技术服务提供商
»  游客             当前位置:  论坛首页 »  自由讨论区 »  Tomcat, WebLogic及J2EE讨论区 »
总帖数
1
每页帖数
101/1页1
返回列表
0
发起投票  发起投票 发新帖子
查看: 3348 | 回复: 0   主题: [原创]局部GC问题的解决        下一篇 
jie.liang
注册用户
等级:少校
经验:1003
发帖:77
精华:0
注册:2013-10-11
状态:离线
发送短消息息给jie.liang 加好友    发送短消息息给jie.liang 发消息
发表于: IP:您无权察看 2014-3-17 17:27:48 | [全部帖] [楼主帖] 楼主

     由于大部分对象第一次分配内存空间都会由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。




赞(0)    操作        顶端 
总帖数
1
每页帖数
101/1页1
返回列表
发新帖子
请输入验证码: 点击刷新验证码
您需要登录后才可以回帖 登录 | 注册
技术讨论