1. 程式人生 > >內存溢出原因及解決方案

內存溢出原因及解決方案

使用 -xmx 遞歸調用 其它 地址 str 啟動 遞歸 對象

參考地址:http://baike.baidu.com/view/79183.htm

內存溢出是指應用系統中存在無法回收的內存或使用的內存過多,最終使得程序運行要用到的內存大於虛擬機能提供的最大內存。

引起內存溢出的原因有很多種,常見的有以下幾種:
  1.內存中加載的數據量過於龐大,如一次從數據庫取出過多數據;
  2.集合類中有對對象的引用,使用完後未清空,使得JVM不能回收;
  3.代碼中存在死循環或循環產生過多重復的對象實體;
  4.使用的第三方軟件中的BUG;
  5.啟動參數內存值設定的過小;

內存溢出的解決方案
第一步,修改JVM啟動參數,直接增加內存。(-Xms,-Xmx參數一定不要忘記加。)


第二步,檢查錯誤日誌,查看“OutOfMemory”錯誤前是否有其它異常或錯誤。

第三步,對代碼進行走查和分析,找出可能發生內存溢出的位置。

重點排查以下幾點:
1.檢查對數據庫查詢中,是否有一次獲得全部數據的查詢。一般來說,如果一次取十萬條記錄到內存,就可能引起內存溢出。這個問題比較隱蔽,在上線前,數據庫中數據較少,不容易出問題,上線後,數據庫中數據多了,一次查詢就有可能引起內存溢出。因此對於數據庫查詢盡量采用分頁的方式查詢。

2.檢查代碼中是否有死循環或遞歸調用。

3.檢查是否有大循環重復產生新對象實體。

4.檢查對數據庫查詢中,是否有一次獲得全部數據的查詢。一般來說,如果一次取十萬條記錄到內存,就可能引起內存溢出。這個問題比較隱蔽,在上線前,數據庫中數據較少,不容易出問題,上線後,數據庫中數據多了,一次查詢就有可能引起內存溢出。因此對於數據庫查詢盡量采用分頁的方式查詢。

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

第四步,使用內存查看工具動態查看內存使用情況。

內存溢出原因及解決方案