java.lang.OutOfMemoryError异常处理总结

来源:互联网 发布:sql server 2005界面 编辑:程序博客网 时间:2024/05/16 15:27

原因:常见的有以下几种:

1.内存中加载的数据量过于庞大,如一次从数据库取出过多数据;

2.集合类中有对对象的引用,使用完后未清空,使得JVM不能回收;

3.代码中存在死循环或循环产生过多重复的对象实体;

4.使用的第三方软件中的BUG;

5.启动参数内存值设定的过小;

 

常见错误提示:

1.tomcat:java.lang.OutOfMemoryError: PermGen space

2.tomcat:java.lang.OutOfMemoryError: Java heap space

3.weblogic:Root cause of ServletException java.lang.OutOfMemoryError

4.resin:java.lang.OutOfMemoryError

5.java:java.lang.OutOfMemoryError

解决;

1.应用服务器提示错误的解决:把启动参数内存值设置足够大。详细请看下列文章: tomcat: http://ajava.org/exep/tomcat/14010.html http://ajava.org/exep/tomcat/14011.html weblogic: http://ajava.org/exep/weblogicyichang/14013.html resin: http://ajava.org/exep/resin/14014.html Jboss: http://ajava.org/exep/jboss/14012.html 2.Java代码导致错误的解决:重点排查以下几点: 1)检查代码中是否有死循环或递归调用。

2)检查是否有大循环重复产生新对象实体。

3)检查对数据库查询中,是否有一次获得全部数据的查询。一般来说,如果一次取十万条记录到内存,就可能引起内存溢出。这个问题比较隐蔽,在上线前,数据库中数据较少,不容易出问题,上线后,数据库中数据多了,一次查询就有可能引起内存溢出。因此对于数据库查询尽量采用分页的方式查询。

4 )检查List、MAP等集合对象是否有使用完后,未清除的问题。List、MAP等集合对象会始终存有对对象的引用,使得这些对象不能被GC回收。

 

网友案例:

1.hibernate查询数据时,一次查询过多的数据,后来调整了该部分的代码,每次只取出指定量的数据,成功的解决该问题。

2.在做压力测试时,出现OutOfMemoryError,发现session的资源一直没有被释放产生的,最好通过session的invalidate()方法将session的资源释放。

3.程序中出现死循环。

4.tomcat部署、运行出现OutOfMemoryError,加大内存参数值,解决此问题。