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
複制
導緻OutOfMemoryError異常的常見原因有以下幾種:
記憶體中加載的資料量過于龐大,如一次從資料庫取出過多資料;
集合類中有對對象的引用,使用完後未清空,使得JVM不能回收;
代碼中存在死循環或循環産生過多重複的對象實體;
使用的第三方軟體中的BUG;
啟動參數記憶體值設定的過小;
此錯誤常見的錯誤提示:
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的記憶體大小。
方法有:
1)在執行某個class檔案時候,可以使用java -Xmx256M aa.class來設定運作aa.class時jvm所允許占用的最大記憶體為256M。
2)對tomcat容器,可以在啟動時對jvm設定記憶體限度。對tomcat,可以在catalina.bat中添加:
set CATALINA_OPTS=-Xms128M -Xmx256M
set JAVA_OPTS=-Xms128M -Xmx256M
或者把%CATALINA_OPTS%和%JAVA_OPTS%代替為-Xms128M -Xmx256M
3)對resin容器,同樣可以在啟動時對jvm設定記憶體限度。在bin檔案夾下建立一個startup.bat檔案,内容如下:
@echo off
call "httpd.exe" "-Xms128M" "-Xmx256M"
:end
其中"-Xms128M"為最小記憶體,"-Xmx256M"為最大記憶體。
二、 優化程式,釋放垃圾。
主要包括避免死循環,應該及時釋放種資源:記憶體, 資料庫的各種連接配接,防止一次載入太多的資料。導緻java.lang.OutOfMemoryError的根本原因是程式不健壯。是以,從根本上解決Java記憶體溢出的唯一方法就是修改程式,及時地釋放沒用的對象,釋放記憶體空間。 遇到該錯誤的時候要仔細檢查程式,嘿嘿,遇多一次這種問題之後,以後寫程式就會小心多了。
Java代碼導緻OutOfMemoryError錯誤的解決:
需要重點排查以下幾點:
檢查代碼中是否有死循環或遞歸調用。
檢查是否有大循環重複産生新對象實體。
檢查對資料庫查詢中,是否有一次獲得全部資料的查詢。一般來說,如果一次取十萬條記錄到記憶體,就可能引起記憶體溢出。這個問題比較隐蔽,在上線前,資料庫中資料較少,不容易出問題,上線後,資料庫中資料多了,一次查詢就有可能引起記憶體溢出。是以對于資料庫查詢盡量采用分頁的方式查詢。
檢查List、MAP等集合對象是否有使用完後,未清除的問題。List、MAP等集合對象會始終存有對對象的引用,使得這些對象不能被GC回收。
tomcat中java.lang.OutOfMemoryError: 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