OutOfMemory Java heap space解決方法

差不多是這樣。。。


//首先檢查程序有沒有限入死循環 

這個問題主要還是由這個問題 java.lang.OutOfMemoryError: Java heap space 引起的。第一次出現這樣的的問題以後,引發了其他的問題。在網上一查可能是JAVA的堆棧設置太小的原因。 
跟據網上的答案大致有這兩種解決方法: 
1、設置環境變量 

解決方法:手動設置Heap size 
修改TOMCAT_HOME/bin/catalina.sh 
set JAVA_OPTS= -Xms32m -Xmx512m 
可以根據自己機器的內存進行更改。 

2、java -Xms32m -Xmx800m className 
就是在執行JAVA類文件時加上這個參數,其中className是需要執行的確類名。(包括包名) 
這個解決問題了。而且執行的速度比沒有設置的時候快很多。 

如果在測試的時候可能會用Eclispe 這時候就需要在Eclipse ->run -arguments 中的VM arguments 中輸入-Xms32m -Xmx800m這個參數就可以了。 

後來在Eclilpse中修改了啓動參數,在VM arguments 加入了-Xms32m -Xmx800m,問題解決。 

一、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 " 

很大的web工程,用tomcat默認分配的內存空間無法啓動,如果不是在myeclipse中啓動tomcat可以對tomcat這樣設置: 

TOMCAT_HOME\bin\catalina.bat 中添加這樣一句話: 

      

          set JAVA_OPTS= -Xmx1024M -Xms512M -XX:MaxPermSize=256m 

如果要在myeclipse中啓動,上述的修改就不起作用了,可如下設置: 

Myeclipse->preferences->myeclipse->servers->tomcat->tomcat×.×->JDK面板中的 

Optional Java VM arguments中添加:-Xmx1024M -Xms512M -XX:MaxPermSize=256m 

以上是轉貼,但本人遇見的問題是:在myeclipse中啓動Tomcat時,提示"ava.lang.OutOfMemoryError: Java heap space",解決辦法就是: 

Myeclipse->preferences->myeclipse->servers->tomcat->tomcat×.×->JDK面板中的 

Optional Java VM arguments中添加:-Xmx1024M -Xms512M -XX:MaxPermSize=256m 

挺靈的。 
--------------------------------------------------------- 
tomcat 啓動內存設置 
其初始空間(即-Xms)是物理內存的1/64,最大空間(-Xmx)是物理內存的1/4。可以利用JVM提供的-Xmn -Xms -Xmx等選項可 
進行設置 
三、實例,以下給出1G內存環境下java jvm 的參數設置參考: 
JAVA_OPTS="-server -Xms800m -Xmx800m -XX:PermSize=64M -XX:MaxNewSize=256m -XX:MaxPermSize=128m -Djava.awt.headless=true " 
JAVA_OPTS="-server -Xms768m -Xmx768m -XX:PermSize=128m -XX:MaxPermSize=256m -XX: 
NewSize=192m -XX:MaxNewSize=384m" 
CATALINA_OPTS="-server -Xms768m -Xmx768m -XX:PermSize=128m -XX:MaxPermSize=256m 
-XX:NewSize=192m -XX:MaxNewSize=384m" 
Linux: 
在/usr/local/apache-tomcat-5.5.23/bin目錄下的catalina.sh 
添加:JAVA_OPTS='-Xms512m -Xmx1024m' 
要加“m”說明是MB,否則就是KB了,在啓動tomcat時會報內存不足。 
-Xms:初始值 
-Xmx:最大值 
-Xmn:最小值 
Windows 
在catalina.bat最前面加入 
set JAVA_OPTS=-Xms128m -Xmx350m 
如果用startup.bat啓動tomcat,OK設置生效.夠成功的分配200M內存. 
但是如果不是執行startup.bat啓動tomcat而是利用windows的系統服務啓動tomcat服務,上面的設置就不生效了, 
就是說set JAVA_OPTS=-Xms128m -Xmx350m 沒起作用.上面分配200M內存就OOM了.. 
windows服務執行的是bin\tomcat.exe.他讀取註冊表中的值,而不是catalina.bat的設置. 
解決辦法: 
修改註冊表HKEY_LOCAL_MACHINE\SOFTWARE\Apache Software Foundation\Tomcat Service Manager\Tomcat5\Parameters\JavaOptions 
原值爲 
-Dcatalina.home="C:\ApacheGroup\Tomcat 5.0" 
-Djava.endorsed.dirs="C:\ApacheGroup\Tomcat 5.0\common\endorsed" 
-Xrs 
加入 -Xms300m -Xmx350m 
重起tomcat服務,設置生效 



================================================================== 





tomcat作爲windows服務的參數配置,特別是PermSize的設置 
當tomcat用startup.bat啓動的時候的參數設置網上說的比較多,這裏就不再描述。 

當tomcat作爲windows的系統服務的時候,網上找了很多相關的文章,都沒有比較全面的參數設置方法,一般就說明了一下xms和xmx的設置,都沒有提供其他方面參數的說明,不夠實用。經過對apache下的procrun的研究和多次試用,總算清楚了一般參數的設置方法。其實 tomcat5.exe本身已經包含有procrun的功能,這就是很多人在網上找不到procrun.exe文件下載的原因。 
procrun可以參考:http://commons.apache.org/daemon/procrun.html 
注:這裏用tomcat5作爲例子,應該同樣適用於tomcat6. 

這裏不使用註冊表,我們用tomcat提供的gui工具來設置。 
1、在命令行下執行:tomcat5w.exe //ES//TomcatService 
其中,TomcatService就是你加入windows服務的名稱。這樣,在windows的任務欄就會出現一個tomcat的服務管理器,圖標如下 。 
2、打開tomcat服務管理器的java頁,如 

在Java Options裏面輸入需要設置的參數,如設置permsize的內存 
-XX:PermSize=64M 
-XX:MaxPermSize=192m 
-XX:ReservedCodeCacheSize=48m 
-Duser.timezone=GMT+08 
注:每一行後面都不能有空格。 

同樣,我們也可以在註冊表中進行修改,HKEY_LOCAL_MACHINE\SOFTWARE\Apache Software Foundation\Procrun 2.0\TestService\Parameters\Java 


-----------http://wangqiaowqo.iteye.com/blog/457912/

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