Tomcat 7優化前及優化后的性能對比
一、運行環境
CPU: Intel(R) Pentium(R) P6200@2.13GHz ;
內存: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
- set JAVA_OPTS=
- -server
- -Xms1000M
- -Xmx1000M #-Xms與-Xmx設成一樣的值,避免JVM因為頻繁的GC導致性能大起大落
- -Xss512k
- -XX:+AggressiveOpts
- -XX:+UseBiasedLocking
- -XX:PermSize=64M
- -XX:MaxPermSize=300M
- -XX:+DisableExplicitGC
- -XX:MaxTenuringThreshold=31
- -XX:+UseConcMarkSweepGC
- -XX:+UseParNewGC
- -XX:+CMSParallelRemarkEnabled
- -XX:+UseCMSCompactAtFullCollection
- -XX:LargePageSizeInBytes=128m
- -XX:+UseFastAccessorMethods
- -XX:+UseCMSInitiatingOccupancyOnly
- -Djava.awt.headless=true
上述這樣的配置,基本上可以達到:
-
系統響應時間增快
-
JVM回收速度增快同時又不影響系統的響應率
-
JVM內存***化利用
-
線程阻塞情況最小化
#p#
2、Tomcat連接參數的優化,主要是針對吞吐量做優化:
修改conf/server.xml文件,把原來
- <Connector port="8080" protocol="HTTP/1.1" />
改成下面的內容
- <Connector port="8080" protocol="HTTP/1.1"
- URIEncoding="UTF-8"
- minSpareThreads="25"
- maxSpareThreads="75"
- enableLookups="false"
- disableUploadTimeout="true"
- connectionTimeout="20000"
- acceptCount="300"
- maxThreads="300"
- maxProcessors="1000"
- minProcessors="5"
- useURIValidationHack="false"
- compression="on"
- compressionMinSize="2048"
- compressableMimeType="text/html,text/xml,text/javascript,text/css,text/plain"
- redirectPort="8443"/>
然后我們再來看看10-1000個并發用戶發起1000個請求時所表現的性能是怎么的。
大家可以看到,經過優化后,吞吐率已經能達到平均1800-1900左右,而處理時間基本能穩定在0.6ms,而等待時間***不到600ms。
四、總結
通過兩個結果對比可以看出,吞吐率及服務器處理時間有很大的改觀,當然在我這破機器上也就這樣一個效果了,再優化估計也不會“飛”起來,有興趣的朋友可以找臺牛B點的機器自己試試。試完了希望告訴我結果,讓我也高興一下。
PS:這是我寫的***篇技術文章,大家將就著看,以后多練練,爭取寫出更有水平的文字來。