2014-5-22 java.lang.OutOfMemoryError: Java heap space的一次诊断

     收到消息某系统一个节点因为内存溢出而宕机,系统的中间件是weblogic,数据库的oracle。

      1. 先用IBM  HeapAnalyzer分析内存溢出时的dump文件,找到占用内存最多的请求,然后看代码。

      2. 在走查代码发现,此类中的方法都特别简单,对单表的增删改查,有查询的地方都是很easy,不会有操作大数据的情况,这样就排除了数据库方面的问题。

      3. 继续走查这个类,发现此类中初始化的时候就创建了16个类,这16个类中又创建了其它的类,揣測此次的内存溢出就是它产生的,须要证明。

      4.用jconsole连接weblogic,找到对应的一个功能,连续按保存button10次,发现内存涨了300多M,确定就是这个问题,在并发的情况下就会出问题。

      5. 改进方法:少做事的原则,把不用的调用去掉,然后把一些类放到方法中减少其作用域。

      本次事件让我想到为什么不能有很大的类存储,还有嵌套许多的调用,写代码的方便和性能一定要有个平衡。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值