原因: 常見的有以下幾種:
1.記憶體中載入的資料量過於龐大,如一次從資料庫取出過多資料;
2.集合類別中有物件的引用,使用完後未清空,使得JVM不能回收;
3.程式碼中存在死循環或循環產生過多重複的物件實體;
4.使用的第三方軟體中的BUG;
5.啟動參數記憶體值設定的過小;
常見錯誤提示: 1.tomcat:java.lang.OutOfMemoryError: PermGen space
2.tomcat:java.lang.OutOfMemoryError: Java heap space
3.weblogic:Rooto. 4.resin:java.lang.OutOfMemoryError5.java:java.lang.OutOfMemoryError 解決 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異常處理中java.lang.OutOfMemoryError: Java heap space異常處理
程式所使用的配置過程、Heap size 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 -Xmx80 " tomcat中java.lang.OutOfMemoryError: PermGen space異常處理一、PermGen space PermGen space的全名為Permanent Generation spacespace,是指記憶區塊的永久儲存區域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 -XXPermSize=64M-XX:Max1建議:將相同的第三方jar檔案移置到tomcat/shared/lib目錄下,這樣可以達到減少jar 文件重複佔用記憶體的目的。提示: "Root cause of ervletException java.lang.OutOfMemoryError"解決方法: 調整bea/weblogic/common中CommEnv中參數:sun if "%PRODUCTION_MODE%" == "truecli" goto _prod ARGS =-Xms256m -Xmx512m -XX:MaxPermSize=256m set JAVA_OPTIONS=%JAVA_OPTIONS% -Xverify:none goto continue :sun_proprod:none goto continue :sun_proprod_pro4m-1445_2_F45_F455_F455_F455_F45_F455_F455_F455_F455_F451(F))5145-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。 這兩個值應該由系統管理員根據伺服器的實際情況進行設定。
轉自:http://www.cnblogs.com/cyjch/archive/2012/04/10/2440421.html