tomcat參數優化
一.Tomcat內存優化
Tomcat內存優化主要是對 tomcat 啟動參數優化,我們可以在 tomcat 的啟動腳本 catalina.sh 中設置 JAVA_OPTS 參數。
1.JAVA_OPTS參數說明
Java代碼
-server 啟用jdk 的 server 版;
-Xms java虛擬機初始化時的最小內存;
-Xmx java虛擬機可使用的最大內存;
-XX:PermSize 內存永久保留區域
-XX:MaxPermSize 內存最大永久保留區域
設置Tomcat啟動的初始內存,其初始空間(即-Xms)是物理內存的1/64,最大空間(-Xmx)是物理內存的1/4。可以利用JVM提供的-Xmn -Xms -Xmx等選項,要加“m”說明是MB,否則就是KB了,在啟動tomcat時會報內存不足。
-Xms:初始值 【初始化內存大小】
-Xmx:最大值 【可以使用的最大內存】
-Xmn:最小值
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值。 這兩個值的大小一般根據需要進行設置。初始化堆的大小執行了虛擬機在啟動時向系統申請的內存的大小。一般而言,這個參數不重要。但是有的應用 程序在大負載的情況下會急劇地占用更多的內存,此時這個參數就是顯得非常重要,如果虛擬機啟動時設置使用的內存比較小而在這種情況下有許多對象進行初始 化,虛擬機就必須重復地增加內存來滿足使用。由於這種原因,我們一般把-Xms和-Xmx設為一樣大,而堆的最大值受限於系統使用的物理內存。一般使用數 據量較大的應用程序會使用持久對象,內存使用有可能迅速地增長。當應用程序需要的內存超出堆的最大值時虛擬機就會提示內存溢出,並且導致應用服務崩潰。因 此一般建議堆的最大值設置為可用內存的最大值的80%。
- 如果系統花費很多的時間收集垃圾,請減小堆大小。一次完全的垃圾收集應該不超過 3-5 秒。如果垃圾收集成為瓶頸,那麽需要指定代的大小,檢查垃圾收集的詳細輸出,研究 垃圾收集參數對性能的影響。一般說來,你應該使用物理內存的 80% 作為堆大小。當增加處理器時,記得增加內存,因為分配可以並行進行,而垃圾收集不是並行的。
- 在重啟你的Tomcat服務器之後,這些配置的更改才會有效。
Windows在文件{tomcathome}/bin/catalina.bat,Unix在文件{tomcathome}/bin/catalina.sh的前面,增加如下設置:
服務器參數配置
tomcat默認: -Xms1024m -Xmx1024m -Xss1024K -XX:PermSize=128m -XX:MaxPermSize=256m
Java_OPTS參數
JAVA_OPTS="-Djava.awt.headless=true -Dfile.encoding=UTF-8
-server -Xms2048m -Xmx2048m
-XX:NewSize=512m -XX:MaxNewSize=512m -XX:PermSize=512m
-XX:MaxPermSize=512m -XX:+DisableExplicitGC"
配置完成後可重啟Tomcat ,通過以下命令進行查看配置是否生效:
1.首先查看Tomcat 進程號:
ps -ef | grep tomcat
我們可以看到Tomcat 進程號是 9217
1.查看是否配置生效:
sudo jmap –heap 9217
我們可以看到MaxHeapSize 等參數已經生效。
二.Tomcat並發優化
1.Tomcat連接相關參數
在Tomcat配置文件conf下面 server.xml 中的配置中和連接數相關的參數有:
minProcessors:最小空閑連接線程數,用於提高系統處理性能,默認值為10
maxProcessors:最大連接線程數,即:並發處理的最大請求數,默認值為75
acceptCount:允許的最大連接數,應大於等於maxProcessors,默認值為100
enableLookups:是否反查域名,取值為:true或false。為了提高處理能力,應設置為false
connectionTimeout:網絡連接超時,單位:毫秒。設置為0表示永不超時,這樣設置有隱患的。通常可設置為30000毫秒。
1.參數說明
默認的tomcat 參數:
<Connector port=“8080" protocol="HTTP/1.1"
connectionTimeout="20000"
redirectPort="8443" />
修改:
<Connector port=“8080" protocol="org.apache.coyote.http11.Http11NioProtocol"
maxThreads="600"
minSpareThreads="100"
maxSpareThreads="500"
acceptCount="700"
connectionTimeout="20000"
redirectPort="8443" />
這樣設置以後,基本上沒有再當機過。
protocol="org.apache.coyote.http11.Http11NioProtocol"
///使用java的異步io護理技術,no blocking IO
maxThreads=“600" 表示最多同時處理600個連接 ///最大線程數
minSpareThreads=“100" 表示即使沒有人使用也開這麽多空線程等待
///初始化時創建的線程數
maxSpareThreads=“500" 表示如果最多可以空500個線程,例如某時刻有505人訪問,之後沒有人訪問了,則tomcat不會保留505個空線程,而是關閉505個空的。
///一旦創建的線程超過這個值,Tomcat就會關閉不再需要的socket線程。
acceptCount="700"//指定當所有可以使用的處理請求的線程數都被使用時,可以放到處理隊列中的請求數,超過這個數的請求將不予處理
這裏是http connector的優化,如果使用apache和tomcat做集群的負載均衡,並且使用ajp協議做apache和tomcat的協議轉發,那麽還需要優化ajp connector。
<Connector port="8009" protocol="AJP/1.3" maxThreads="600" minSpareThreads="100" maxSpareThreads="500" acceptCount="700" connectionTimeout="20000" redirectPort="8443" />
解決常遇到的一些報錯
一、Tomcat的JVM提示內存溢出
查看%TOMCAT_HOME%\logs文件夾下,日誌文件是否有內存溢出錯誤
二、修改Tomcat的JVM
1、錯誤提示:java.lang.OutOfMemoryError: Java heap space
Tomcat默認可以使用的內存為128MB,在較大型的應用項目中,這點內存是不夠的,有可能導致系統無法運行。常見的問題是報Tomcat內存溢出錯誤,Out of Memory(系統內存不足)的異常,從而導致客戶端顯示500錯誤,一般調整Tomcat的使用內存即可解決此問題。
windows環境下修改
“%TOMCAT_HOME%\bin\catalina.bat”文件,在文件開頭增加如下設置:JAVA_OPTS=-Xms2048m -Xmx2048m
Linux環境下修改
“%TOMCAT_HOME%\bin\catalina.sh”文件,在文件開頭增加如下設置:JAVA_OPTS=-Xms2048m -Xmx2048m
其中,-Xms設置初始化內存大小,-Xmx設置可以使用的最大內存。
跟我上面那麽設置就可以了。
2、錯誤提示: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)那麽就會產生此錯誤信息了。
解決方法:
在catalina.bat的第一行增加:
set JAVA_OPTS=-Xms64m -Xmx256m -XX:PermSize=128M -XX:MaxNewSize=256m - XX:MaxPermSize=256m
在catalina.sh的第一行增加:
JAVA_OPTS=-Xms64m -Xmx256m -XX:PermSize=128M -XX:MaxNewSize=256m XX:MaxPermSize=256m
三、查看Tomcat的JVM內存
- Tomcat6中沒有設置任何默認用戶,因而需要手動往Tomcat6的conf文件夾下的tomcat-users.xml文件中添加用戶。 如:
- <role rolename="manager"/>
<user username="tomcat" password="tomcat" roles="manager"/>
註:添加完需要重啟Tomcat6。
- 訪問http://localhost:8080/manager/status,輸入上面添加的用戶名和密碼。
- 然後在如下面的JVM下可以看到內存的使用情況。
tomcat參數優化