您的位置:首页 > 编程语言 > Java开发

java.lang.OutOfMemoryError异常解决方法

2012-01-10 01:41 736 查看
from: http://hi.baidu.com/cjxgotofly/blog/item/ef981434e2e112355ab5f55f.html java.lang.outofmemoryerror异常解决方法
原因:
常见的有以下几种:
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.应用服务器提示错误的解决:
把启动参数内存值设置足够大。
2.java代码导致错误的解决:
重点排查以下几点:
1)检查代码中是否有死循环或递归调用。
2)检查是否有大循环重复产生新对象实体。
3)检查对数据库查询中,是否有一次获得全部数据的查询。一般来说,如果一次取十万条记录到内存,就可能引起内存溢出。这个问题比较隐蔽,在上线前,数据库中数据较少,不容易出问题,上线后,数据库中数据多了,一次查询就有可能引起内存溢出。因此对于数据库查询尽量采用分页的方式查询。
4 )检查list、map等集合对象是否有使用完后,未清除的问题。list、map等集合对象会始终存有对对象的引用,使得这些对象不能被gc回收。
案例:
1.hibernate查询数据时,一次查询过多的数据,后来调整了该部分的代码,每次只取出指定量的数据,成功的解决该问题。
2.在做压力测试时,出现outofmemoryerror,发现session的资源一直没有被释放产生的,最好通过session的invalidate()方法将session的资源释放。
3.程序中出现死循环。
4.tomcat部署、运行出现outofmemoryerror,加大内存参数值,解决此问题。
tomcat中java.lang.outofmemoryerror: java heap space异常处理
一、heap size
jvm堆的设置是指java程序运行过程中jvm可以调配使用的内存空间的设置.jvm在启动的时候会自动设置heap size的值,
其初始空间(即-xms)是物理内存的1/64,最大空间(-xmx)是物理内存的1/4。可以利用jvm提供的-xmn -xms -xmx等选项可
进行设置。heap size 的大小是young generation 和tenured generaion 之和。
提示:在jvm中如果98%的时间是用于gc且可用的heap size 不足2%的时候将抛出此异常信息。
提示:heap size 最大不要超过可用物理内存的80%,一般的要将-xms和-xmx选项设置为相同,而-xmn为1/4的-xmx值。
二、解决方法:手动设置heap size
修改tomcat_home/bin/catalina.sh
在“echo "using catalina_base:$catalina_base"”上面加入以下行:
java_opts="-server -xms800m -xmx800m-xx:maxnewsize=256m"
tomcat中java.lang.outofmemoryerror: permgen space异常处理
一、permgen space
permgen space的全称是permanent generation space,是指内存的永久保存区域,
这块内存主要是被jvm存放class和meta信息的,class在被loader时就会被放到permgen space中,
它和存放类实例(instance)的heap区域不同,gc(garbage collection)不会在主程序运行期对
permgen space进行清理,所以如果你的应用中有很多class的话,就很可能出现permgen space错误,
这种错误常见在web服务器对jsp进行pre compile的时候。如果你的web app下都用了大量的第三方jar, 其大小
超过了jvm默认的大小(4m)那么就会产生此错误信息了。
解决方法: 手动设置maxpermsize大小
修改tomcat_home/bin/catalina.sh
在“echo "using catalina_base:$catalina_base"”上面加入以下行:
java_opts="-server -xx:permsize=64m -xx:maxpermsize=128m
建议:将相同的第三方jar文件移置到tomcat/shared/lib目录下,这样可以达到减少jar 文档重复占用内存的目的。
weblogic中java.lang.outofmemoryerror异常处理
错误提示:
"root cause of ervletexception java.lang.outofmemoryerror"
解决办法:
调整bea/weblogic/common中commenv中参数
:sun
if "%production_mode%" == "true" goto sun_prod_mode
set java_vm=-client
set mem_args=-xms256m -xmx512m -xx:maxpermsize=256m
set java_options=%java_options% -xverify:none
goto continue
:sun_prod_mode
set java_vm=-server
set mem_args=-xms256m -xmx512m -xx:maxpermsize=256m
goto continue
eclipse运行jboss时java.lang.outofmemoryerror:permgen space异常处理
在eclipse中运行jboss时,时间太长可能有时候会出现java.lang.outofmemoryerror:permgen space的错误,这里给介绍大家一种解决方法:
1)点击debug图标旁边的小箭头;
2)点击”debug configurations…”菜单项;
3)选左边的“generic server”树下面的“jboss v4.2 at localhost”;
4)点击右边的“arguments”tab页签,在“vm arguments”中添加:
-dprogram.name=run.bat -djava.endorsed.dirs="d:/jboss405/bin/../lib/endorsed" -xms128m -xmx512m -xx:permsize=64m -xx:maxpermsize=256m
5)如果你是以命令行模式或者直接点击“run.bat”来运行jboss,那你就要在 bin/run.conf 文件中对jvm选项作修改了,找到 java_opts="-xms128m -xmx512m…” 这一段,然后在后面加上 “ -xx:permsize=64m -xx:maxpermsize=256m”。保存就ok了。
6)注意:其中128、512、64和256等数字可以根据自己机器的配置来做一些相应的调整,然后点击“apply”就可以了。
resin下java.lang.outofmemoryerror异常处理
原因:
出现这个错误,一般是因为jvm物理内存过小。默认的java虚拟机最大内存仅为64兆,这在开发调试过程中可能没有问题,但在实际的应用环境中是远远不能满足需要的,除非你的应用非常小,也没什么访问量。否则你可能会发现程序运行一段时间后包java.lang.outofmemoryerror的错误。因此我们需要提升resin可用的虚拟机内存的大小。
解决:
修改/usr/local/resin/bin/httpd.sh中的args选项
添加参数-xms(初始内存)和-xmx(最大能够使用内存大小)
可以用来限制jvm的物理内存使用量。
例如:
args="-xms128m -xmx256m"
设置后,jvm初始物理内存是128m,最大能使用物理内存为256m。
这两个值应该由系统管理员根据服务器的实际情况进行设置。

======================================================

在最后,我邀请大家参加新浪APP,就是新浪免费送大家的一个空间,支持PHP+MySql,免费二级域名,免费域名绑定
这个是我邀请的地址,您通过这个链接注册即为我的好友,并获赠云豆500个,价值5元哦!短网址是http://t.cn/SXOiLh我创建的小站每天访客已经达到2000+了,每天挂广告赚50+元哦,呵呵,饭钱不愁了,\(^o^)/
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: