java.lang.OutOfMemoryError錯誤

今天遇到了java.lang.OutOfMemoryError錯誤,解決發現問題。

 

 

經過查找資料,可能出現的問題和解決辦法如下:
 
1.String其實是沒有限制的,而是當String太大了,超過JVM的自身的內存後會拋出java.lang.OutOfMemoryError錯誤


String是沒有長度限制的,而是有JVM的內存限制了String的長度。同時說明,並不會拋出任何Exception而只會拋出Error.
OutMemoryError表明程序的設計差,或者遇到了超出編程人員所預想的大批量的數據。不管哪種情況,都只有下面這幾種解決辦法。它們是:
設計人員重新設計程序,不致使程序一次載入所有的數據。

數據可以分割成更小的塊。

可以爲程序分配更多的內存。

爲Java虛擬機提供更多的內存。
 
2.一般都是發生在開啓大型檔案或跟數據庫一次拿了太多的數據,造成 Out Of Memory Error 的狀況,這時就大概要計算一下數據量的最大值是多少,並且設定所需最小及最大的內存空間值。

另一種狀況平時比較難查覺。就是 Servlet JSP Container 突然同時上線人數爆增,也相對造成內存需求不足,所以也必須要計算出程序所需的數據量*同時上線人數,來設定內存的需求量。(如果要有最佳化的值,最好是配合 gc 做調校)

有一種說法是聽來的,實際上是不是如此還有待確認。

CPU 速度愈快,內存的最小需求量也就必需愈大。原因是 CPU 愈快,短時間內能處理的數據量也就愈大,所以在 java GC 之前,可能已經內存已經消耗完了,所以 CPU 的速度也是內存初始需求量的重要因素之一。

目前這三項應該足以應付絕大部份 Out Of Memory Error 的狀況,其它造成 Out Of Memory Error 的狀況,等有遇到再來補充。

 

方法:
 
修改JAVA_OPTS="-Xms1024m -Xmx1024m" 或更大,根據系統內存情況
 
   
內存溢出的情況很大可能性是程序設計過程中不注意消耗內存的細節編碼造成的。
但是編碼後期來發現問題需要付出的勞動會很多,很不容易 。
 
http://www.matrix.org.cn/resource/article/43/43639_Memory_Leaks.html
http://www.pconline.com.cn/pcedu/empolder/gj/java/0509/699218.html
 
有關java內存的文章
和內存溢出查找原因的一個方法。
=====================================================
jsp開發中有關java.lang.OutOfMemoryError的產生及解決方法
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
作者:淘特網
出處:淘特網
注:轉載請註明出處
這裏以tomcat環境爲例,其它WEB服務器如jboss,weblogic等是同一個道理。
一、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 文檔重複佔用內存的目的。

二、java.lang.OutOfMemoryError: Java heap space
Heap size 設置
JVM堆的設置是指java程序運行過程中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 -Xmx800m   -XX:MaxNewSize=256m"

三、實例,以下給出1G內存環境下java jvm 的參數設置參考:

JAVA_OPTS="-server -Xms800m -Xmx800m  -XX:PermSize=64M -XX:MaxNewSize=256m -XX:MaxPermSize=128m -Djava.awt.headless=true "

Windows
set JAVA_OPTS=%JAVA_OPTS% -Xms128m -Xmx256m -XX:PermSize=128m -XX:MaxPermSize=256m -XX:MaxNewSize=256m -Dfile.encoding=GBK
echo "JAVA_OPTS="$JAVA_OPTS

Linux
JAVA_OPTS="$JAVA_OPTS -Xms128m -Xmx256m -XX:PermSize=128m -XX:MaxPermSize=256m -XX:MaxNewSize=256m -Dfile.encoding=GBK"
echo "JAVA_OPTS="$JAVA_OPTS

三、相關資料

/show/3/7/20061112220131.htm

/show/3/7/20061112220054.htm

/show/3/7/20061112220201.htm

題外話:經常看到網友抱怨tomcat的性能不如...,不穩定等,其實根據筆者幾年的經驗,從"互聯星空“到現在的房產門戶網,我們
均使用tomcat作爲WEB服務器,每天訪問量百萬多,tomcat仍然運行良好。建議大家有問題多從自己程序入手,多看看java的DOC文檔
並詳細瞭解JVM的知識。這樣開發的程序纔會健壯。

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