1. 程式人生 > >java虛擬機器常見錯誤 -- java.lang.OutOfMemoryError: Java heap space解決辦法

java虛擬機器常見錯誤 -- java.lang.OutOfMemoryError: 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