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
10 |
-XX:+DisableExplicitGC |
11 |
-XX:MaxTenuringThreshold=31 |
12 |
-XX:+UseConcMarkSweepGC |
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" |
06 |
disableUploadTimeout = "true" |
07 |
connectionTimeout = "20000" |
12 |
useURIValidationHack = "false" |
14 |
compressionMinSize = "2048" |
15 |
compressableMimeType = "text/html,text/xml,text/javascript,text/css,text/plain" |
然後我們再來看看10-1000個併發用戶發起1000個請求時所表現的性能是怎麼的。
大家可以看到,經過優化後,吞吐率已經能達到平均1800-1900左右,而處理時間基本能穩定在0.6ms,而等待時間最高不到600ms。
四、總結
通過兩個結果對比可以看出,吞吐率及服務器處理時間有很大的改觀,當然在我這破機器上也就這樣一個效果了,再優化估計也不會“飛”起來,有興趣的朋友可以找臺牛B點的機器自己試試。試完了希望告訴我結果,讓我也高興一下。