码迷,mamicode.com
首页 > 编程语言 > 详细

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

时间:2014-05-26 04:54:58      阅读:333      评论:0      收藏:0      [点我收藏+]

标签:style   blog   c   java   a   文件   

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

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

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

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

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

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

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

2014-5-22 java.lang.OutOfMemoryError: Java heap space的一次诊断,布布扣,bubuko.com

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

标签:style   blog   c   java   a   文件   

原文地址:http://blog.csdn.net/stevendbaguo/article/details/26609223

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!