2014-5-22 java.lang.OutOfMemoryError: Java heap space的一次诊断
2016-01-02 11:58
537 查看
收到消息某系统一个节点因为内存溢出而宕机。系统的中间件是weblogic。数据库的oracle。
1. 先用IBM HeapAnalyzer分析内存溢出时的dump文件,找到占用内存最多的请求,然后看代码。
2. 在走查代码发现,此类中的方法都特别简单,对单表的增删改查,有查询的地方都是很easy。不会有操作大数据的情况,这样就排除了数据库方面的问题。
3. 继续走查这个类,发现此类中初始化的时候就创建了16个类,这16个类中又创建了其它的类。揣測此次的内存溢出就是它产生的,须要证明。
4.用jconsole连接weblogic,找到对应的一个功能,连续按保存button10次。发现内存涨了300多M,确定就是这个问题,在并发的情况下就会出问题。
5. 改进方法:少做事的原则,把不用的调用去掉,然后把一些类放到方法中减少其作用域。
本次事件让我想到为什么不能有很大的类存储,还有嵌套许多的调用,写代码的方便和性能一定要有个平衡。
1. 先用IBM HeapAnalyzer分析内存溢出时的dump文件,找到占用内存最多的请求,然后看代码。
2. 在走查代码发现,此类中的方法都特别简单,对单表的增删改查,有查询的地方都是很easy。不会有操作大数据的情况,这样就排除了数据库方面的问题。
3. 继续走查这个类,发现此类中初始化的时候就创建了16个类,这16个类中又创建了其它的类。揣測此次的内存溢出就是它产生的,须要证明。
4.用jconsole连接weblogic,找到对应的一个功能,连续按保存button10次。发现内存涨了300多M,确定就是这个问题,在并发的情况下就会出问题。
5. 改进方法:少做事的原则,把不用的调用去掉,然后把一些类放到方法中减少其作用域。
本次事件让我想到为什么不能有很大的类存储,还有嵌套许多的调用,写代码的方便和性能一定要有个平衡。
相关文章推荐
- Java 接口归纳
- java中泛型的继承
- Eclipse连接mysql
- java集合:链表:Java:LinkedList<E>
- spring mvc
- Java final 关键字
- java编译运行详解
- java 内部类 和 匿名内部类
- java成员方法
- Win7 64位安装JDK的步骤,并且附上测试程序
- java初始化之变量初始化
- Java super和this的异同总结
- spring05 spring的配置信息
- java中的包
- spring04 数据库操作 spring+jdbc/hibernate 及其声明式事务处理
- (4)通过调用hadoop的java api实现本地文件上传到hadoop文件系统上
- spring03 AOP、各种通知、一/多个切面例子
- spring02 注解方式实现MVC、spring的继承、代理模式(静/动) :jdk动态代理,cglib动态代理
- spring01 环境搭建、控制反转、依赖注入、springIOC和DI实现MVC模式
- eclipse(ini)