Java 內存溢出(java.lang.OutOfMemoryError)的常見情況和處理方式總結

java.lang.OutOfMemoryError這個錯誤我相信大部分開發人員都有遇到過,產生該錯誤的原因大都出於以下原因:JVM內存過小、程序不嚴密,產生了過多的垃圾。

導致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

解決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錯誤的解決:

需要重點排查以下幾點:

  1. 檢查代碼中是否有死循環或遞歸調用。
  2. 檢查是否有大循環重複產生新對象實體。
  3. 檢查對數據庫查詢中,是否有一次獲得全部數據的查詢。一般來說,如果一次取十萬條記錄到內存,就可能引起內存溢出。這個問題比較隱蔽,在上線前,數據庫中數據較少,不容易出問題,上線後,數據庫中數據多了,一次查詢就有可能引起內存溢出。因此對於數據庫查詢儘量採用分頁的方式查詢。
  4. 檢查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

建議:將相同的第三方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

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。

這兩個值應該由系統管理員根據服務器的實際情況進行設置。

發佈了120 篇原創文章 · 獲贊 11 · 訪問量 22萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章