JAVA記憶體溢出解決方案總結__JAVA

來源:互聯網
上載者:User


一 原因

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

 


三 解決原則

1.應用伺服器提示錯誤的解決:把啟動參數記憶體值設定足夠大。

2.Java代碼導致錯誤的解決:重點排查以下幾點:

①檢查代碼中是否有死迴圈或遞迴調用。

②檢查是否有大迴圈重複產生新對象實體。

③檢查對資料庫查詢中,是否有一次獲得全部資料的查詢。一般來說,如果一次取十萬條記錄到記憶體,就可能引起記憶體溢出。這個問題比較隱蔽,在上線前,資料庫中資料較少,

不容易出問題,上線後,資料庫中資料多了,一次查詢就有可能引起記憶體溢出。因此對於資料庫查詢盡量採用分頁的方式查詢。

④檢查List、MAP等集合對象是否有使用完後,未清除的問題。List、MAP等集合對象會始終存有對對象的引用,使得這些對象不能被GC回收。

 


四 異常舉例

 

1 tomcat中java.lang.OutOfMemoryError: Java heap space異常處理

 

① Heap size

 

JVM堆的設定是指java程式運行過程中JVM可以調配使用的記憶體空間的設定。JVM在啟動的時候會自動化佈建Heap size的值,其初始空間(即-Xms)是實體記憶體的1/64,最大空間(-Xmx)是實體記憶體的1/4。可以利用JVM提供的-Xmn -Xms -Xmx等選項可進行設定。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 -Xmx800m   -XX:MaxNewSize=256m"

 


2 tomcat中java.lang.OutOfMemoryError: PermGen space異常處理

 

① 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 文檔重複佔用記憶體的目的。

 

 

3 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

 

 

4 Eclipse運行Jboss時java.lang.OutOfMemoryError:PermGen space異常處理

 

在Eclipse中運行Jboss時,時間太長可能有時候會出現java.lang.OutOfMemoryError:PermGen space的錯誤,這裡給介紹大家一種

解決方案。

 

① 點擊debug表徵圖旁邊的小箭頭

 

② 點擊”Debug Configurations…”功能表項目

 

③ 選左邊的“Generic Server”樹下面的“JBoss v4.2 at localhost”

 

④ 點擊右邊的“Arguments”Tab頁簽,在“VM arguments”中添加:

    -Dprogram.name=run.bat -Djava.endorsed.dirs="D:/JBoss405/bin/../lib/endorsed" -Xms128m -Xmx512m -XX:PermSize=64m -

    XX:MaxPermSize=256m

 

⑤ 如果你是以命令列模式或者直接點擊“run.bat”來運行JBoss,那你就要在 bin/run.conf 檔案中對JVM選項作修改了,找到

     JAVA_OPTS="-Xms128m -Xmx512m…” 這一段,然 後在後面加上“-XX:PermSize=64m -XX:MaxPermSize=256m”

 

⑥  注意:其中128、512、64和256等數字可以根據自己機器的配置來做一些相應的調整,然後點擊“Apply”就可以了

 

 

5 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。這兩個值應該由系統管理員根據伺服器的實際情況進行設定。

 

 


五 典型案例

 

1 hibernate查詢資料時,一次查詢過多的資料,後來調整了該部分的代碼,每次只取出指定量的資料,成功的解決該問題。

 

2 在做壓力測試時,出現OutOfMemoryError,發現session的資源一直沒有被釋放產生的,

   最好通過session的invalidate()方法將session的資源釋放。

 

3 程式中出現死迴圈。

 

4 tomcat部署、運行出現OutOfMemoryError,加大記憶體參數值,解決此問題。

 

原帖地址:http://mars914.iteye.com/blog/1446497

 

 

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.