1、java
tomcat內存設置問題 收藏web
在使用Java程序從數據庫中查詢大量的數據或是應用服務器(如tomcat、jboss,weblogic)加載jar包時會出現java.lang.OutOfMemoryError異常。這主要是因爲應用服務器的內存不足引發的。這種異經常有如下幾種狀況(如下以tomcat環境爲例,其它WEB服務器如jboss,weblogic等是同一個道理):數據庫
1. java.lang.OutOfMemoryError: PermGen spacewindows
PermGen space的全稱是Permanent Generation space,是指內存的永久保存區域OutOfMemoryError: PermGen space。從文字上看就是內存溢出,解決方法是加大內存。爲何會內存溢出,這是因爲這塊內存主要是被JVM存放Class和Meta信息的,Class在被Load的時候被放入PermGen space區域,它和存放Instance的Heap區域不一樣,GC(Garbage Collection)不會在主程序運行期對PermGen space進行清理,因此若是你的APP會LOAD不少CLASS的話,就極可能出現PermGen space錯誤。這種錯誤常見在web服務器對JSP進行pre compile的時候。若是你的WEB APP下都用了大量的第三方jar, 其大小超過了jvm默認的大小(4M)那麼就會產生此錯誤信息了。tomcat
解決方法: 手動設置MaxPermSize大小服務器
a.若是tomcat是以bat方式啓動的,則以下設置:jvm
修改TOMCAT_HOME/bin/catalina.sh性能
在「echo "Using CATALINA_BASE: $CATALINA_BASE"」上面加入如下行:測試
JAVA_OPTS="-server -XX:PermSize=64M -XX:MaxPermSize=128mspa
b.若是tomcat是註冊成了windows服務,以services方式啓動的,則須要修改註冊表中的相應鍵值。
打開註冊表,找到目錄HKEY_LOCAL_MACHINE\SOFTWARE\Apache Software Foundation\Procrun 2.0\htfty\Parameters\Java,其中目錄地址中紅色標註的(如htfty)須要根據不一樣狀況做修改,爲tomcat服務註冊成windows服務的名稱。 能夠看到JvmMs和JvmMx項,其中JvmMs設置最小的內存使用參數,JvmMx設置最大的內存使用參數。設置好JvmMs和JvmMx項的值,重啓tomcat服務器便可生效。
建議:將相同的第三方jar文件移置到tomcat/shared/lib目錄下,這樣能夠達到減小jar 文檔重複佔用內存的目的。
2. java.lang.OutOfMemoryError: Java heap space
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
a.若是tomcat是以bat方式啓動的,則以下設置:
修改TOMCAT_HOME/bin/catalina.sh
在「echo "Using CATALINA_BASE: $CATALINA_BASE"」上面加入如下行:
JAVA_OPTS="-server -Xms800m -Xmx800m -XX:MaxNewSize=256m"
b.若是tomcat是註冊成了windows服務,以services方式啓動的,則須要修改註冊表中的相應鍵值。
打開註冊表,找到目錄HKEY_LOCAL_MACHINE\SOFTWARE\Apache Software Foundation\Procrun 2.0\htfty\Parameters\Java,其中目錄地址中紅色標註的(如htfty)須要根據不一樣狀況做修改,爲tomcat服務註冊成windows服務的名稱。 能夠看到JvmMs和JvmMx項,其中JvmMs設置最小的內存使用參數,JvmMx設置最大的內存使用參數。設置好JvmMs和JvmMx項的值,重啓tomcat服務器便可生效。
提示:Heap Size 最大不要超過可用物理內存的80%,通常的要將-Xms和-Xmx選項設置爲相同,而-Xmn爲1/4的-Xmx值。
2、Tomcat自己不能直接在計算機上運行,須要依賴於硬件基礎之上的操做系統和一個java虛擬機。JAVA程序啓動時JVM都會分配一個初始內存和最大內存給這個應用程序。這個初始內存和最大內存在必定程度都會影響程序的性能。好比說在應用程序用到最大內存的時候,JVM是要先去作垃圾回收的動做,釋放被佔用的一些內存。因此想調整Tomcat的啓動時初始內存和最大內存就須要向JVM聲明,通常的JAVA程序在運行均可以經過中-Xms -Xmx來調整應用程序的初始內存和最大內存: 這兩個值的大小通常根據須要進行設置。初始化堆的大小執行了虛擬機在啓動時向系統申請的內存的大小。通常而言,這個參數不重要。可是有的應用程序在大負載的狀況下會急劇地佔用更多的內存,此時這個參數就是顯得很是重要,若是虛擬機啓動時設置使用的內存比較小而在這種狀況下有許多對象進行初始化,虛擬機就必須重複地增長內存來知足使用。因爲這種緣由,咱們通常把-Xms和-Xmx設爲同樣大,而堆的最大值受限於系統使用的物理內存。通常使用數據量較大的應用程序會使用持久對象,內存使用有可能迅速地增加。當應用程序須要的內存超出堆的最大值時虛擬機就會提示內存溢出,而且致使應用服務崩潰。所以通常建議堆的最大值設置爲可用內存的最大值的80%。
Tomcat默承認以使用的內存爲128MB,在較大型的應用項目中,這點內存是不夠的,須要調大。有如下幾種方法能夠選用:
第一種方法:
Windows下,在文件/bin/catalina.bat,Unix下,在文件/bin/catalina.sh的前面,增長以下設置:
JAVA_OPTS='-Xms【初始化內存大小】 -Xmx【可使用的最大內存】'
須要把這個兩個參數值調大。例如:
JAVA_OPTS='-Xms256m -Xmx512m'
表示初始化內存爲256MB,可使用的最大內存爲512MB。
第二種方法: 環境變量中設 變量名:JAVA_OPTS 變量值:-Xms512m -Xmx512m
第三種方法:前兩種方法針對的是bin目錄下有catalina.bat的狀況(好比直接解壓的Tomcat等),可是有些安裝版的Tomcat下沒有catalina.bat,這個時候能夠採用以下方法,固然這個方法也是最通用的方法:打開tomcatHome/\bin/\tomcat5w.exe,點擊Java選項卡,而後將會發現其中有這麼兩項:Initial memory pool和Maximum memory pool.Initial memory pool這個就是初始化設置的內存的大小。Maximum memory pool這個是最大內存的大小 設置完了就按肯定而後再重啓TOMCAT你就會發現tomcat中jvm可用的內存改變了
另外須要考慮的是Java提供的垃圾回收機制。虛擬機的堆大小決定了虛擬機花費在收集垃圾上的時間和頻度。收集垃圾能夠接受的速度與應用有關,應該經過分析實際的垃圾收集的時間和頻率來調整。若是堆的大小很大,那麼徹底垃圾收集就會很慢,可是頻度會下降。若是你把堆的大小和內存的須要一致,徹底收集就很快,可是會更加頻繁。調整堆大小的的目的是最小化垃圾收集的時間,以在特定的時間內最大化處理客戶的請求。在基準測試的時候,爲保證最好的性能,要把堆的大小設大,保證垃圾收集不在整個基準測試的過程當中出現。 若是系統花費不少的時間收集垃圾,請減少堆大小。一次徹底的垃圾收集應該不超過 3-5 秒。若是垃圾收集成爲瓶頸,那麼須要指定代的大小,檢查垃圾收集的詳細輸出,研究 垃圾收集參數對性能的影響。通常說來,你應該使用物理內存的 80% 做爲堆大小。當增長處理器時,記得增長內存,由於分配能夠並行進行,而垃圾收集不是並行的。
一個要注意的地方:建議把內存的最高值跟最低值的差值縮小,否則會浪費不少內存的, 最低值加大 ,最高值能夠隨便設,可是要根據實際的物理內存 ,若是內存設置太大了,好比設置了512M最大內存,但若是沒有512M可用內存,Tomcat就不能啓動,還有可能存在內存被系統回收,終止進程的狀況