Tomcat作為Web服務(wù)器,它的處理性能直接關(guān)系到用戶體驗,下面是幾種常見的優(yōu)化措施。
1. 掉對web.xml的監(jiān)視,把jsp提前編輯成Servlet。
有富余物理內(nèi)存的情況,加大Tomcat使用的JVM的內(nèi)存。
2. 服務(wù)器資源
服務(wù)器所能提供CPU、內(nèi)存、硬盤的性能對處理能力有決定性影響。
2.1 對于高并發(fā)情況下會有大量的運算,那么CPU的速度會直接影響到處理速度。
2.2 內(nèi)存在大量數(shù)據(jù)處理的情況下,將會有較大的內(nèi)存容量需求,可以用-Xmx -Xms -XX:MaxPermSize等參數(shù)對內(nèi)存不同功能塊進(jìn)行劃分。我們之前就遇到過內(nèi)存分配不足,導(dǎo)致虛擬機一直處于full GC,從而導(dǎo)致處理能力嚴(yán)重下降。
2.3 硬盤主要問題就是讀寫性能,當(dāng)大量文件進(jìn)行讀寫時,磁盤極容易成為性能瓶頸。最好的辦法還是利用下面提到的緩存。
3. 利用緩存和壓縮
對于靜態(tài)頁面最好是能夠緩存起來,這樣就不必每次從磁盤上讀。這里我們采用了Nginx作為緩存服務(wù)器,將圖片、css、js文件都進(jìn)行了緩存,有效的減少了后端tomcat的訪問。
另外,為了能加快網(wǎng)絡(luò)傳輸速度,開啟gzip壓縮也是必不可少的。但考慮到tomcat已經(jīng)需要處理很多東西了,所以把這個壓縮的工作就交給前端的Nginx來完成。
除了文本可以用gzip壓縮,其實很多圖片也可以用圖像處理工具預(yù)先進(jìn)行壓縮,找到一個平衡點可以讓畫質(zhì)損失很小而文件可以減小很多。曾經(jīng)我就見過一個圖片從300多kb壓縮到幾十kb,自己幾乎看不出來區(qū)別。
4. 采用集群
單個服務(wù)器性能總是有限的,最好的辦法自然是實現(xiàn)橫向擴展,那么組建tomcat集群是有效提升性能的手段。我們還是采用了Nginx來作為請求分流的服務(wù)器,后端多個tomcat共享session來協(xié)同工作。
5. 優(yōu)化tomcat參數(shù)
這里以tomcat7的參數(shù)配置為例,需要修改conf/server.xml文件,主要是優(yōu)化連接配置,關(guān)閉客戶端dns查詢。
<Connector port="8080"
protocol="org.apache.coyote.http11.Http11NioProtocol"
connectionTimeout="20000"
redirectPort="8443"
maxThreads="500"
minSpareThreads="20"
acceptCount="100"
disableUploadTimeout="true"
enableLookups="false"
URIEncoding="UTF-8" />