java.lang.OutOfMemoryError: GC overhead limit exceeded
原因:
常見的有以下幾種:
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代碼導致錯誤的解決:
重點排查以下幾點:
1)檢查代碼中是否有死迴圈或遞迴調用。
2)檢查是否有大迴圈重複產生新對象實體。
3)檢查對資料庫查詢中,是否有一次獲得全部資料的查詢。一般來說,如果一次取十萬條記錄到記憶體,就可能引起記憶體溢出。這個問題比較隱蔽,在上線前,資料庫中資料較少,不容易出問題,上線後,資料庫中資料多了,一次查詢就有可能引起記憶體溢出。因此對於資料庫查詢盡量採用分頁的方式查詢。
4 )檢查List、MAP等集合對象是否有使用完後,未清除的問題。List、MAP等集合對象會始終存有對對象的引用,使得這些對象不能被GC回收。
案例:
1.hibernate查詢資料時,一次查詢過多的資料,後來調整了該部分的代碼,每次只取出指定量的資料,成功的解決該問題。
2.在做壓力測試時,出現OutOfMemoryError,發現session的資源一直沒有被釋放產生的,最好通過session的invalidate()方法將session的資源釋放。
3.程式中出現死迴圈。
4.tomcat部署、運行出現OutOfMemoryError,加大記憶體參數值,解決此問題。