Tomcat優化------(二)

Tomcat性能優化方案整理

考慮一下這種場景,你開發了一個應用,它有十分優 秀的佈局設計,最新的特性以及其它的優秀特點。但是在性能這方面欠缺,不管這個應用如何都會遭到客戶拒絕。客戶總是期望它們的應用應該有更好的性能。如果 你在產品中使用了Tomcat服務器,那麼這篇文章就會給你幾方面來提升Tomcat服務器的性能經過沉思我已經知道了和早期版本相比最新的Tomcat提供更好的性能和穩定性。所以一直使用最新的Tomcat版本。現在本文使用下面幾步來提高Tomcat服務器的性能。

1. 增加JVM堆內存大小 

2. 修復JRE內存泄漏 

3. 線程池設置

4. 壓縮

5. 數據庫性能調優

6. Tomcat本地庫

7. 其它選項 

第一步  – 提高JVM棧內存Increase JVM heap memory 

你使用過tomcat的話,簡單的說就是內存溢出”. 通常情況下,這種問題出現在實際的生產環境中.產生這種問題的原因是tomcat使用較少 的內存給進程,通過配置TOmcat的配置文件(Windows 下的catalina.batLinux下的catalina.sh)可以解決這種問 題.這種解決方法是通過增加JVM的棧內存實現的.也就是說,JVM通常不去調用垃圾回收器,所以服務器可以更多關注處理web請求,並要求儘快完成。要 更改文件(catalina.sh) 位於"\tomcat server folder\bin\catalina.sh",下面,給出這個文件的配置信息,

[plain] view plain copy print?

1. JAVA_OPTS="-Djava.awt.headless=true -Dfile.encoding=UTF-8  

2.     -server -Xms1024m -Xmx1024m  

3.     -XX:NewSize=512m -XX:MaxNewSize=512m -XX:PermSize=512m  

4.     -XX:MaxPermSize=512m -XX:+DisableExplicitGC"  

-Xms – 指定初始化時化的棧內存

-Xms – 指定初始化時化的棧內存
-Xmx – 指定最大棧內存
在重啓你的Tomcat服務器之後,這些配置的更改纔會有效。下面將介紹如何處理JRE內存泄漏.  

第二步解決JRE內存泄露 

性能表現不佳的另一個主要原因是內存泄漏,正 如我之前說過:始終使用最新的tomcat服務器以獲得更好的性能和可伸縮性。現在,這句話變成真的。如果我們使用最新的tomcat版本6.0.26及 以上就可以解決這個錯誤,因爲它包含了一個監聽器來處理JREPermGen的內存泄漏。使用的監聽器是,

[html] view plain copy print?

1. <Listener className="org.apache.catalina.core.JreMemoryLeakPreventionListener" />  

你可以在server.xml文件中找到這個監聽器的配置,server.xml位置在“tomcat project folder/conf/server.xml”。接下來,我們將看看如何調整連接屬性“maxThreads”

第三步線程池設置 

線程池指定Web請求負載的數量,因此,爲獲得更好的性能這部分應小心處理。可以通過調整連接器屬性“maxThreads”完成設置。maxThreads的值應該根據流量的大小,如果值過低,將有沒有足夠的線程來處理所有的請求,請求將進入等待狀態,只有當一個的處理線程釋放後才被處理;如果設置的太大,Tomcat的啓動將花費更多時間。因此它取決於我們給maxThreads設置一個正確的值

[html] view plain copy print?

1. <Connector port="8080" address="localhost"  

2. 2   maxThreads="250" maxHttpHeaderSize="8192"  

3. 3   emptySessionPath="true" protocol="HTTP/1.1"  

4. 4   enableLookups="false" redirectPort="8181" acceptCount="100"  

5. 5   connectionTimeout="20000" disableUploadTimeout="true" />  

 

在上述配置中,maxThreads值設定爲“250”,這指定可以由服務器處理的併發請求的最大數量。如果沒有指定,這個屬性的默認值爲“200”。任何多出的併發請求將收到拒絕連接的錯誤提示,直到另一個處理請求進程被釋放。錯誤看起來如下,

[java] view plain copy print?

1. org.apache.tomcat.util.threads.ThreadPool logFull SEVERE: All threads (250) are  

2. currently busy, waiting. Increase maxThreads (250) or check the servlet status  

如果應用提示上述錯誤,務必檢查上述錯誤是否是由於單個請求花費太長時間造成的,這個問題的原因是這樣的,有時候如果數據庫連接不釋放的話,進程將不會處理其它請求。  

注意: 如果請求的數量超過了“750”,這將不是意味着將maxThreads屬性值設置爲 “750”,它意外着最好使用“Tomcat集羣”的多個實例。也就是說,如果有“1000”請求,兩個Tomcat實例設置“maxThreads= 500”,而不在單Tomcat實例的情況下設置maxThreads=1000。

根據我的經驗,準確值的設定可以通過將應用在在各種環境中測試得出。接下來,我們來看看如何壓縮的MIME類型。

4- 壓縮 

Tomcat有一個通過在server.xml配置文件中設置壓縮的選項。壓縮可以在connector像如下設置中完成,

[html] view plain copy print?

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

2. 2   connectionTimeout="20000"  

3. 3   redirectPort="8181" compression="500"  

4. 4   compressableMimeType="text/html,text/xml,text/plain,application/octet-stream" />  

在前面的配置中,當文件的大小大於等於500bytes時纔會壓縮。如果當文件達到了大小但是卻沒有被壓縮,那麼設置屬性compression="on"。否則Tomcat默認設置是“off”。接下來我們將看看如何調優數據庫。  

第五步- 數據庫性能調優 

Tomcat性能在等待數據庫查詢被執行期間會降低。如今大多數應用程序都是使用可能包含命名查詢的關係型數據庫。如果是那樣的 話,Tomcat會在啓動時默認加載命名查詢,這個可能會提升性能。另一件重要事是確保所有數據庫連接正確地關閉。給數據庫連接池設置正確值也是十分重要 的。我所說的值是指Resource要素的最大空閒數(maxIdle),最大連接數(maxActive,最大建立連接等待時間(maxWait)屬 性的值。因爲配置依賴與應用要求,我也不能在本文指定正確的值。你可以通過調用數據庫性能測試來找到正確的值。  

6– Tomcat原生庫 

Tomcat的原生庫基於Apache可移植運行時(Apache Portable Runtime簡稱APR),給程序員提供了超強的擴展性和性能,在產品運作中幫助融合原生的服務器技術以展現最佳的性能。想知道安裝說明的朋友請參考Tomcat Native Library – (APR) Installation 

7其他選項 

這些選項是:

· 開啓瀏覽器的緩存,這樣讀取存放在webapps文件夾裏的靜態內容會更快,大大推動整體性能。

· 每當開機時,Tomcat服務器應當自動地重啓。 

· 一般情況下HTTPS請求會比HTTP請求慢。如果你想要更好的安全性,即使慢一點我們還是要選擇HTTPS  

tomcat內存優化

linux修改TOMCAT_HOME/bin/catalina.sh,在前面加入

JAVA_OPTS="-XX:PermSize=64M -XX:MaxPermSize=128m -Xms512m -Xmx1024m -Duser.timezone=Asia/Shanghai"

windows修改TOMCAT_HOME/bin/catalina.bat,在前面加入

set JAVA_OPTS=-XX:PermSize=64M -XX:MaxPermSize=128m -Xms512m -Xmx1024m

最大堆內存是1024m,對於現在的硬件還是偏低,實施時,還是按照機器具體硬件配置優化。

 

tomcat 線程優化

<Connector port="80" protocol="HTTP/1.1" maxThreads="600" minSpareThreads="100" maxSpareThreads="500" acceptCount="700"

connectionTimeout="20000" redirectPort="8443" />

maxThreads="600"       ///最大線程數
minSpareThreads="100"///初始化時創建的線程數
maxSpareThreads="500"///一旦創建的線程超過這個值,Tomcat就會關閉不再需要的socket線程。
acceptCount="700"//指定當所有可以使用的處理請求的線程數都被使用時,可以放到處理隊列中的請求數,超過這個數的請求將不予處理

 

這裏是http connector的優化,如果使用apachetomcat做集羣的負載均衡,並且使用ajp協議做apachetomcat的協議轉發,那麼還需要優化ajp connector

<Connector port="8009" protocol="AJP/1.3" maxThreads="600" minSpareThreads="100" maxSpareThreads="500" acceptCount="700"

connectionTimeout="20000" redirectPort="8443" />

 

由於tomcat有多個connector,所以tomcat線程的配置,又支持多個connector共享一個線程池。

首先。打開/conf/server.xml,增加

<Executor name="tomcatThreadPool" namePrefix="catalina-exec-" maxThreads="500" minSpareThreads="20" maxIdleTime="60000" />

最大線程500(一般服務器足以),最小空閒線程數20,線程最大空閒時間60秒。

 

然後,修改<Connector ...>節點,增加executor屬性,executor設置爲線程池的名字:

<Connector executor="tomcatThreadPool" port="80" protocol="HTTP/1.1"  connectionTimeout="60000" keepAliveTimeout="15000" maxKeepAliveRequests="1"  redirectPort="443" />

可以多個connector公用1個線程池,所以ajp connector也同樣可以設置使用tomcatThreadPool線程池。

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章