java.lang.OutOfMemoryError: PermGen space

java.lang.OutOfMemoryError: PermGen space

Exception: java.lang.OutOfMemoryError thrown from the UncaughtExceptionHandler

-Xms800m -Xmx1024m -XX:PermSize=512M -XX:MaxNewSize=256m -XX:MaxPermSize=512m -Dantx.properties=/Users/jack/aipqa/swork.info/swork.info.server/antx.properties -Dpandora.location=/Users/jack/soft/taobao-tomcat-7.0.68/deploy/taobao-hsf.sar

22:09:22.597 java.lang.ThreadGroup uncaughtException
System.err: Exception in thread "RMI TCP Connection(idle)" 
java.lang.OutOfMemoryError: PermGen space[2017-10-19 10:09:22,790] Artifact swork.info.server:war exploded: Error during artifact deployment. See server log for details.
2017-10-19 22:09:23.690 java.lang.ThreadGroup uncaughtException
System.err: Exception in thread "RMI TCP Connection(idle)" 
java.lang.OutOfMemoryError: PermGen space22:09:44.815 [JmonitorClient-CheckThread Pool [Thread-1]] ERROR c.a.a.jmonitor.client.JmonitorClient - Connection refused
2017-10-19 22:09:59.284 java.lang.ThreadGroup uncaughtException
System.err: Exception in thread "RMI TCP Connection(idle)" 
java.lang.OutOfMemoryError: PermGen space

導(dǎo)致OutOfMemoryError異常的常見原因有以下幾種:

內(nèi)存中加載的數(shù)據(jù)量過于龐大,如一次從數(shù)據(jù)庫取出過多數(shù)據(jù);
集合類中有對對象的引用,使用完后未清空,使得JVM不能回收;
代碼中存在死循環(huán)或循環(huán)產(chǎn)生過多重復(fù)的對象實(shí)體;
使用的第三方軟件中的BUG;
啟動參數(shù)內(nèi)存值設(shè)定的過??;
此錯誤常見的錯誤提示:

tomcat:java.lang.OutOfMemoryError: PermGen space
tomcat:java.lang.OutOfMemoryError: Java heap space
weblogic:Root cause of ServletException java.lang.OutOfMemoryError
resin:java.lang.OutOfMemoryError
java:java.lang.OutOfMemoryError
解決java.lang.OutOfMemoryError的方法有如下幾種:

一、增加jvm的內(nèi)存大小。

方法有:

1)在執(zhí)行某個class文件時候,可以使用java -Xmx256M aa.class來設(shè)置運(yùn)行aa.class時jvm所允許占用的最大內(nèi)存為256M。

2)對tomcat容器,可以在啟動時對jvm設(shè)置內(nèi)存限度。對tomcat,可以在catalina.bat中添加:

set CATALINA_OPTS=-Xms128M -Xmx256M
set JAVA_OPTS=-Xms128M -Xmx256M
或者把%CATALINA_OPTS%和%JAVA_OPTS%代替為-Xms128M -Xmx256M

3)對resin容器,同樣可以在啟動時對jvm設(shè)置內(nèi)存限度。在bin文件夾下創(chuàng)建一個startup.bat文件,內(nèi)容如下:

@echo off
call "httpd.exe" "-Xms128M" "-Xmx256M"
:end
其中"-Xms128M"為最小內(nèi)存,"-Xmx256M"為最大內(nèi)存。

二、 優(yōu)化程序,釋放垃圾。

主要包括避免死循環(huán),應(yīng)該及時釋放種資源:內(nèi)存, 數(shù)據(jù)庫的各種連接,防止一次載入太多的數(shù)據(jù)。導(dǎo)致java.lang.OutOfMemoryError的根本原因是程序不健壯。因此,從根本上解決Java內(nèi)存溢出的唯一方法就是修改程序,及時地釋放沒用的對象,釋放內(nèi)存空間。 遇到該錯誤的時候要仔細(xì)檢查程序,嘿嘿,遇多一次這種問題之后,以后寫程序就會小心多了。

Java代碼導(dǎo)致OutOfMemoryError錯誤的解決:

需要重點(diǎn)排查以下幾點(diǎn):

檢查代碼中是否有死循環(huán)或遞歸調(diào)用。
檢查是否有大循環(huán)重復(fù)產(chǎn)生新對象實(shí)體。
檢查對數(shù)據(jù)庫查詢中,是否有一次獲得全部數(shù)據(jù)的查詢。一般來說,如果一次取十萬條記錄到內(nèi)存,就可能引起內(nèi)存溢出。這個問題比較隱蔽,在上線前,數(shù)據(jù)庫中數(shù)據(jù)較少,不容易出問題,上線后,數(shù)據(jù)庫中數(shù)據(jù)多了,一次查詢就有可能引起內(nèi)存溢出。因此對于數(shù)據(jù)庫查詢盡量采用分頁的方式查詢。
檢查List、MAP等集合對象是否有使用完后,未清除的問題。List、MAP等集合對象會始終存有對對象的引用,使得這些對象不能被GC回收。
tomcat中java.lang.OutOfMemoryError: PermGen space異常處理

PermGen space的全稱是Permanent Generation space,是指內(nèi)存的永久保存區(qū)域,這塊內(nèi)存主要是被JVM存放Class和Meta信息的,Class在被Loader時就會被放到PermGen space中, 它和存放類實(shí)例(Instance)的Heap區(qū)域不同,GC(Garbage Collection)不會在主程序運(yùn)行期對PermGen space進(jìn)行清理,所以如果你的應(yīng)用中有很多CLASS的話,就很可能出現(xiàn)PermGen space錯誤, 這種錯誤常見在web服務(wù)器對JSP進(jìn)行pre compile的時候。如果你的WEB APP下都用了大量的第三方j(luò)ar, 其大小超過了jvm默認(rèn)的大小(4M)那么就會產(chǎn)生此錯誤信息了。 解決方法: 手動設(shè)置MaxPermSize大小修改TOMCAT_HOME/bin/catalina.sh在

echo "Using CATALINA_BASE: $CATALINA_BASE"
上面加入以下行:

JAVA_OPTS="-server -XX:PermSize=64M -XX:MaxPermSize=128m

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容