Tomcat 7優化前及優化後的性能對比

Tomcat 7在我們日常開發、測試、生產環境都會使用到,但對於大部分開發人員來說,對其性能還是沒有多大瞭解。本文就對它做一次性能測試,對比優化前後的性能區別。

一、運行環境

CPU: Intel(R) Pentium(R) [email protected]  ;

內存:4G,裝的是32位win7,只認出3G,沒有花時間去整ramdisk之類的東西;

操作系統:win7 32位;

JDK:1.7.0_55

Tomcat:7.0.53

大家不要笑,公司電腦,就給配這樣的,慢的要死,悲劇!

下面所有測試都是基於1000個請求做的,且都是訪問Tomcat默認的ROOT首頁

二、未調優前

併發用戶數從10-1000挨個測試,測試結果如下:

從上面的測試結果來看,除去200用戶併發的時候(這時候可能在做GC),吞吐率和請求處理時間都比較穩定,但請求等待時間到後面就颼颼的往上漲了。經觀察,CPU負載均在80%以下。

 

三、優化後

優化主要是對Tomcat做的,主要有兩方面:

1、在bin/catalina.bat文件中加入下面參數,對JVM進行優化,至於這一大駝參數的作用及說明,大家到網上找找,應該有很多的,如:http://www.mzone.cc/article/321.html

01 set JAVA_OPTS=
02 -server 
03 -Xms1000M 
04 -Xmx1000M   #-Xms與-Xmx設成一樣的值,避免JVM因爲頻繁的GC導致性能大起大落
05 -Xss512k 
06 -XX:+AggressiveOpts 
07 -XX:+UseBiasedLocking 
08 -XX:PermSize=64M 
09 -XX:MaxPermSize=300M 
10 -XX:+DisableExplicitGC 
11 -XX:MaxTenuringThreshold=31 
12 -XX:+UseConcMarkSweepGC 
13 -XX:+UseParNewGC  
14 -XX:+CMSParallelRemarkEnabled 
15 -XX:+UseCMSCompactAtFullCollection 
16 -XX:LargePageSizeInBytes=128m  
17 -XX:+UseFastAccessorMethods 
18 -XX:+UseCMSInitiatingOccupancyOnly 
19 -Djava.awt.headless=true

上述這樣的配置,基本上可以達到:

  •  系統響應時間增快

  • JVM回收速度增快同時又不影響系統的響應率

  • JVM內存最大化利用

  • 線程阻塞情況最小化


2、Tomcat連接參數的優化,主要是針對吞吐量做優化:

修改conf/server.xml文件,把原來

1 <Connector port="8080" protocol="HTTP/1.1" />

改成下面的內容

01   <Connector port="8080" protocol="HTTP/1.1"
02            URIEncoding="UTF-8"  
03            minSpareThreads="25" 
04            maxSpareThreads="75"
05            enableLookups="false" 
06            disableUploadTimeout="true" 
07            connectionTimeout="20000"
08            acceptCount="300"   
09            maxThreads="300" 
10            maxProcessors="1000" 
11            minProcessors="5"
12            useURIValidationHack="false"
13            compression="on" 
14            compressionMinSize="2048"
15            compressableMimeType="text/html,text/xml,text/javascript,text/css,text/plain"
16            redirectPort="8443"/>


然後我們再來看看10-1000個併發用戶發起1000個請求時所表現的性能是怎麼的。

大家可以看到,經過優化後,吞吐率已經能達到平均1800-1900左右,而處理時間基本能穩定在0.6ms,而等待時間最高不到600ms。

四、總結

通過兩個結果對比可以看出,吞吐率及服務器處理時間有很大的改觀,當然在我這破機器上也就這樣一個效果了,再優化估計也不會“飛”起來,有興趣的朋友可以找臺牛B點的機器自己試試。試完了希望告訴我結果,讓我也高興一下。

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