java.lang.OutOfMemoryError异常解决方法
java.lang.OutOfmemoryError:
PermGen Space 的錯(cuò)誤,導(dǎo)致項(xiàng)目無(wú)法正常運(yùn)行。
? 出現(xiàn)這個(gè)錯(cuò)誤的原因,總結(jié)一下:
PermGen Space指的是內(nèi)存的永久保存區(qū),該塊內(nèi)存主要是被JVM存放class和mete信息的,當(dāng)class被加載loader的時(shí)候
就會(huì)被存儲(chǔ)到該內(nèi)存區(qū)中,與存放類(lèi)的實(shí)例的heap區(qū)不同,java中的垃圾回收器GC不會(huì)在主程序運(yùn)行期對(duì)PermGen space
進(jìn)行清理,所以當(dāng)我們的應(yīng)用中有很多的class時(shí),很可能就會(huì)出現(xiàn)PermGen space的錯(cuò)誤。
??? 解決方法:
?1. 手動(dòng)設(shè)置MaxPermSize的大小
??? 修改 TOMCAT_HOME/bin/catalina.bat(Linux上為catalina.sh)文件,在echo "using CATALINA_BASE:$CATALINA_BASE"上面加入這一行內(nèi)容:
set JAVA_OPTS=%JAVA_OPTS% -server -XX:PermSize=128m -XX:MaxPermSize=512m
?
catalina.sh修改如下:
JAVA_OPTS="$JAVA_OPTS" -server -XX:PermSize=128m -XX:MaxSize=512m
?
2.修改 TOMCAT_HOME/bin/catalina.bat文件的內(nèi)容:在 %_EXECJAVA% %JAVA_OPTS% 后面添加 -Xms=256m -Xmx512m? 注意哦,前后后有空格的
例如: %_EXECJAVA% %JAVA_OPTS% -Xms=256m -Xmx512m(空格)后面的內(nèi)容不變
?
?
3. 可以考慮將相同的第三方j(luò)ar文件拷貝到tomcat/shared/lib 目錄下,這樣可以減少jar文件重復(fù)占用內(nèi)存的。
java.lang.OutOfMemoryError異常解決方法
原因:
常見(jiàn)的有以下幾種:
1.內(nèi)存中加載的數(shù)據(jù)量過(guò)于龐大,如一次從數(shù)據(jù)庫(kù)取出過(guò)多數(shù)據(jù);
2.集合類(lèi)中有對(duì)對(duì)象的引用,使用完后未清空,使得JVM不能回收;
3.代碼中存在死循環(huán)或循環(huán)產(chǎn)生過(guò)多重復(fù)的對(duì)象實(shí)體;
4.使用的第三方軟件中的BUG;
5.啟動(dòng)參數(shù)內(nèi)存值設(shè)定的過(guò)小;
常見(jiàn)錯(cuò)誤提示:
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.應(yīng)用服務(wù)器提示錯(cuò)誤的解決:
把啟動(dòng)參數(shù)內(nèi)存值設(shè)置足夠大。
?
2.Java代碼導(dǎo)致錯(cuò)誤的解決:
重點(diǎn)排查以下幾點(diǎn):
1)檢查代碼中是否有死循環(huán)或遞歸調(diào)用。
2)檢查是否有大循環(huán)重復(fù)產(chǎn)生新對(duì)象實(shí)體。
3)檢查對(duì)數(shù)據(jù)庫(kù)查詢(xún)中,是否有一次獲得全部數(shù)據(jù)的查詢(xún)。一般來(lái)說(shuō),如果一次取十萬(wàn)條記錄到內(nèi)存,就可能引起內(nèi)存溢出。這個(gè)問(wèn)題比較隱蔽,在上線前,數(shù)據(jù)庫(kù)中數(shù)據(jù)較少,不容易出問(wèn)題,上線后,數(shù)據(jù)庫(kù)中數(shù)據(jù)多了,一次查詢(xún)就有可能引起內(nèi)存溢出。因此對(duì)于數(shù)據(jù)庫(kù)查詢(xún)盡量采用分頁(yè)的方式查詢(xún)。
4?)檢查L(zhǎng)ist、MAP等集合對(duì)象是否有使用完后,未清除的問(wèn)題。List、MAP等集合對(duì)象會(huì)始終存有對(duì)對(duì)象的引用,使得這些對(duì)象不能被GC回收。
?
tomcat中java.lang.OutOfMemoryError:?Java?heap?space異常處理
一、Heap?size?
JVM堆的設(shè)置是指java程序運(yùn)行過(guò)程中JVM可以調(diào)配使用的內(nèi)存空間的設(shè)置.JVM在啟動(dòng)的時(shí)候會(huì)自動(dòng)設(shè)置Heap?size的值,
其初始空間(即-Xms)是物理內(nèi)存的1/64,最大空間(-Xmx)是物理內(nèi)存的1/4。可以利用JVM提供的-Xmn?-Xms?-Xmx等選項(xiàng)可
進(jìn)行設(shè)置。Heap?size?的大小是Young?Generation?和Tenured?Generaion?之和。
提示:在JVM中如果98%的時(shí)間是用于GC且可用的Heap?size?不足2%的時(shí)候?qū)伋龃水惓P畔ⅰ?br /> 提示:Heap?Size?最大不要超過(guò)可用物理內(nèi)存的80%,一般的要將-Xms和-Xmx選項(xiàng)設(shè)置為相同,而-Xmn為1/4的-Xmx值。
二、解決方法:手動(dòng)設(shè)置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的全稱(chēng)是Permanent?Generation?space,是指內(nèi)存的永久保存區(qū)域,
這塊內(nèi)存主要是被JVM存放Class和Meta信息的,Class在被Loader時(shí)就會(huì)被放到PermGen?space中,
它和存放類(lèi)實(shí)例(Instance)的Heap區(qū)域不同,GC(Garbage?Collection)不會(huì)在主程序運(yùn)行期對(duì)
PermGen?space進(jìn)行清理,所以如果你的應(yīng)用中有很多CLASS的話(huà),就很可能出現(xiàn)PermGen?space錯(cuò)誤,
這種錯(cuò)誤常見(jiàn)在web服務(wù)器對(duì)JSP進(jìn)行pre?compile的時(shí)候。如果你的WEB?APP下都用了大量的第三方j(luò)ar,?其大小
超過(guò)了jvm默認(rèn)的大小(4M)那么就會(huì)產(chǎn)生此錯(cuò)誤信息了。
解決方法:?手動(dòng)設(shè)置MaxPermSize大小
修改TOMCAT_HOME/bin/catalina.sh
在“echo?"Using?CATALINA_BASE:???$CATALINA_BASE"”上面加入以下行:
JAVA_OPTS="-server?-XX:PermSize=64M?-XX:MaxPermSize=128m
建議:將相同的第三方j(luò)ar文件移置到tomcat/shared/lib目錄下,這樣可以達(dá)到減少jar?文檔重復(fù)占用內(nèi)存的目的。
?
?
weblogic中java.lang.OutOfMemoryError異常處理
錯(cuò)誤提示:
"Root?cause?of?ervletException?java.lang.OutOfMemoryError"
解決辦法:
調(diào)整bea/weblogic/common中CommEnv中參數(shù)
?: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運(yùn)行Jboss時(shí)java.lang.OutOfMemoryError:PermGen?space異常處理
在Eclipse中運(yùn)行Jboss時(shí),時(shí)間太長(zhǎng)可能有時(shí)候會(huì)出現(xiàn)java.lang.OutOfMemoryError:PermGen?space的錯(cuò)誤,這里給介紹大家一種解決方法:
1)點(diǎn)擊debug圖標(biāo)旁邊的小箭頭;
2)點(diǎn)擊”Debug?Configurations…”菜單項(xiàng);
3)選左邊的“Generic?Server”樹(shù)下面的“JBoss?v4.2?at?localhost”;
4)點(diǎn)擊右邊的“Arguments”Tab頁(yè)簽,在“VM?arguments”中添加:
-Dprogram.name=run.bat?-Djava.endorsed.dirs="D:/JBoss405/bin/../lib/endorsed"?-Xms128m?-Xmx512m?-XX:PermSize=64m?-XX:MaxPermSize=256m
5)如果你是以命令行模式或者直接點(diǎn)擊“run.bat”來(lái)運(yùn)行JBoss,那你就要在?bin/run.conf?文件中對(duì)JVM選項(xiàng)作修改了,找到?JAVA_OPTS="-Xms128m?-Xmx512m…”?這一段,然后在后面加上?“?-XX:PermSize=64m?-XX:MaxPermSize=256m”。保存就OK了。
6)注意:其中128、512、64和256等數(shù)字可以根據(jù)自己機(jī)器的配置來(lái)做一些相應(yīng)的調(diào)整,然后點(diǎn)擊“Apply”就可以了。
?
?
Resin下java.lang.OutOfMemoryError異常處理
原因:
出現(xiàn)這個(gè)錯(cuò)誤,一般是因?yàn)镴VM物理內(nèi)存過(guò)小。默認(rèn)的Java虛擬機(jī)最大內(nèi)存僅為64兆,這在開(kāi)發(fā)調(diào)試過(guò)程中可能沒(méi)有問(wèn)題,但在實(shí)際的應(yīng)用環(huán)境中是遠(yuǎn)遠(yuǎn)不能滿(mǎn)足需要的,除非你的應(yīng)用非常小,也沒(méi)什么訪問(wèn)量。否則你可能會(huì)發(fā)現(xiàn)程序運(yùn)行一段時(shí)間后包java.lang.OutOfMemoryError的錯(cuò)誤。因此我們需要提升resin可用的虛擬機(jī)內(nèi)存的大小。
解決:
修改/usr/local/resin/bin/httpd.sh中的args選項(xiàng)
添加參數(shù)-Xms(初始內(nèi)存)和-Xmx(最大能夠使用內(nèi)存大小)
可以用來(lái)限制JVM的物理內(nèi)存使用量。
例如:
args="-Xms128m?-Xmx256m"
設(shè)置后,JVM初始物理內(nèi)存是128m,最大能使用物理內(nèi)存為256m。
這兩個(gè)值應(yīng)該由系統(tǒng)管理員根據(jù)服務(wù)器的實(shí)際情況進(jìn)行設(shè)置。
案例:
1.hibernate查詢(xún)數(shù)據(jù)時(shí),一次查詢(xún)過(guò)多的數(shù)據(jù),后來(lái)調(diào)整了該部分的代碼,每次只取出指定量的數(shù)據(jù),成功的解決該問(wèn)題。
2.在做壓力測(cè)試時(shí),出現(xiàn)OutOfMemoryError,發(fā)現(xiàn)session的資源一直沒(méi)有被釋放產(chǎn)生的,最好通過(guò)session的invalidate()方法將session的資源釋放。
3.程序中出現(xiàn)死循環(huán)。
4.tomcat部署、運(yùn)行出現(xiàn)OutOfMemoryError,加大內(nèi)存參數(shù)值,解決此問(wèn)題。
總結(jié)
以上是生活随笔為你收集整理的java.lang.OutOfMemoryError异常解决方法的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: mybatis插入mysql出现中文乱码
- 下一篇: 概率选择