隨筆-72  評論-20  文章-0  trackbacks-1

          Tomcat本身不能直接在計(jì)算機(jī)上運(yùn)行,需要依賴于硬件基礎(chǔ)之上的操作系統(tǒng)和一個(gè)java虛擬機(jī)。您可以選擇自己的需要選擇不同的操作系統(tǒng)和對應(yīng)的JDK的版本(只要是符合Sun發(fā)布的Java規(guī)范的),但我們推薦您使用Sun公司發(fā)布的JDK。確保您所使用的版本是最新的,因?yàn)镾un公司和其它一些公司一直在為提高性能而對java虛擬機(jī)做一些升級(jí)改進(jìn)。一些報(bào)告顯示JDK1.4在性能上比JDK1.3提高了將近10%到20%。

          可以給Java虛擬機(jī)設(shè)置使用的內(nèi)存,但是如果你的選擇不對的話,虛擬機(jī)不會(huì)補(bǔ)償。可通過命令行的方式改變虛擬機(jī)使用內(nèi)存的大小。如下表所示有兩個(gè)參數(shù)用來設(shè)置虛擬機(jī)使用內(nèi)存的大小。

          參數(shù)

          描述

          -Xms

          JVM初始化堆的大小

          -Xmx

          JVM堆的最大值

          這兩個(gè)值的大小一般根據(jù)需要進(jìn)行設(shè)置。初始化堆的大小執(zhí)行了虛擬機(jī)在啟動(dòng)時(shí)向系統(tǒng)申請的內(nèi)存的大小。一般而言,這個(gè)參數(shù)不重要。但是有的應(yīng)用程序在大負(fù)載的情況下會(huì)急劇地占用更多的內(nèi)存,此時(shí)這個(gè)參數(shù)就是顯得非常重要,如果虛擬機(jī)啟動(dòng)時(shí)設(shè)置使用的內(nèi)存比較小而在這種情況下有許多對象進(jìn)行初始化,虛擬機(jī)就必須重復(fù)地增加內(nèi)存來滿足使用。由于這種原因,我們一般把-Xms和-Xmx設(shè)為一樣大,而堆的最大值受限于系統(tǒng)使用的物理內(nèi)存。一般使用數(shù)據(jù)量較大的應(yīng)用程序會(huì)使用持久對象,內(nèi)存使用有可能迅速地增長。當(dāng)應(yīng)用程序需要的內(nèi)存超出堆的最大值時(shí)虛擬機(jī)就會(huì)提示內(nèi)存溢出,并且導(dǎo)致應(yīng)用服務(wù)崩潰。因此一般建議堆的最大值設(shè)置為可用內(nèi)存的最大值的80%。

          Tomcat默認(rèn)可以使用的內(nèi)存為128MB,在較大型的應(yīng)用項(xiàng)目中,這點(diǎn)內(nèi)存是不夠的,需要調(diào)大。

          Windows下,在文件/bin/catalina.bat,Unix下,在文件/bin/catalina.sh的前面,增加如下設(shè)置:

          JAVA_OPTS='-Xms【初始化內(nèi)存大小】 -Xmx【可以使用的最大內(nèi)存】'

          需要把這個(gè)兩個(gè)參數(shù)值調(diào)大。例如:

          JAVA_OPTS='-Xms256m -Xmx512m'

          表示初始化內(nèi)存為256MB,可以使用的最大內(nèi)存為512MB。

          另外需要考慮的是Java提供的垃圾回收機(jī)制。虛擬機(jī)的堆大小決定了虛擬機(jī)花費(fèi)在收集垃圾上的時(shí)間和頻度。收集垃圾可以接受的速度與應(yīng)用有關(guān),應(yīng)該通過分析實(shí)際的垃圾收集的時(shí)間和頻率來調(diào)整。如果堆的大小很大,那么完全垃圾收集就會(huì)很慢,但是頻度會(huì)降低。如果你把堆的大小和內(nèi)存的需要一致,完全收集就很快,但是會(huì)更加頻繁。調(diào)整堆大小的的目的是最小化垃圾收集的時(shí)間,以在特定的時(shí)間內(nèi)最大化處理客戶的請求。在基準(zhǔn)測試的時(shí)候,為保證最好的性能,要把堆的大小設(shè)大,保證垃圾收集不在整個(gè)基準(zhǔn)測試的過程中出現(xiàn)。

          如果系統(tǒng)花費(fèi)很多的時(shí)間收集垃圾,請減小堆大小。一次完全的垃圾收集應(yīng)該不超過 3-5 秒。如果垃圾收集成為瓶頸,那么需要指定代的大小,檢查垃圾收集的詳細(xì)輸出,研究 垃圾收集參數(shù)對性能的影響。一般說來,你應(yīng)該使用物理內(nèi)存的 80% 作為堆大小。當(dāng)增加處理器時(shí),記得增加內(nèi)存,因?yàn)榉峙淇梢圆⑿羞M(jìn)行,而垃圾收集不是并行的。

          Tomcat 5常用優(yōu)化和配置

          1、JDK內(nèi)存優(yōu)化:

          Tomcat默認(rèn)可以使用的內(nèi)存為128MB,Windows下,在文件{tomcat_home}/bin/catalina.bat,Unix下,在文件{tomcat_home}/bin/catalina.sh的前面,增加如下設(shè)置:

          JAVA_OPTS='-Xms[初始化內(nèi)存大小] -Xmx[可以使用的最大內(nèi)存]

          一般說來,你應(yīng)該使用物理內(nèi)存的 80% 作為堆大小。

          2、連接器優(yōu)化:

          在tomcat配置文件server.xml中的配置中,和連接數(shù)相關(guān)的參數(shù)有:

          maxThreads:

          Tomcat使用線程來處理接收的每個(gè)請求。這個(gè)值表示Tomcat可創(chuàng)建的最大的線程數(shù)。默認(rèn)值200。

          acceptCount:

          指定當(dāng)所有可以使用的處理請求的線程數(shù)都被使用時(shí),可以放到處理隊(duì)列中的請求數(shù),超過這個(gè)數(shù)的請求將不予處理。默認(rèn)值10。

          minSpareThreads:

          Tomcat初始化時(shí)創(chuàng)建的線程數(shù)。默認(rèn)值4。

          maxSpareThreads:

          一旦創(chuàng)建的線程超過這個(gè)值,Tomcat就會(huì)關(guān)閉不再需要的socket線程。默認(rèn)值50。

          enableLookups:

          是否反查域名,默認(rèn)值為true。為了提高處理能力,應(yīng)設(shè)置為false

          connnectionTimeout:

          網(wǎng)絡(luò)連接超時(shí),默認(rèn)值60000,單位:毫秒。設(shè)置為0表示永不超時(shí),這樣設(shè)置有隱患的。通常可設(shè)置為30000毫秒。

          maxKeepAliveRequests:

          保持請求數(shù)量,默認(rèn)值100。

          bufferSize:

          輸入流緩沖大小,默認(rèn)值2048 bytes。

          compression:

          壓縮傳輸,取值on/off/force,默認(rèn)值off。

          其中和最大連接數(shù)相關(guān)的參數(shù)為maxThreads和acceptCount。如果要加大并發(fā)連接數(shù),應(yīng)同時(shí)加大這兩個(gè)參數(shù)。web server允許的最大連接數(shù)還受制于操作系統(tǒng)的內(nèi)核參數(shù)設(shè)置,通常Windows是2000個(gè)左右,Linux是1000個(gè)左右。

          3、tomcat中如何禁止和允許列目錄下的文件

          在{tomcat_home}/conf/web.xml中,把listings參數(shù)設(shè)置成false即可,如下:

          <servlet>
                      ...
                      <init-param>
                      <param-name>listings</param-name>
                      <param-value>false</param-value>
                      </init-param>
                      ...
                      </servlet>
                      4、tomcat中如何禁止和允許主機(jī)或IP地址訪問
                      <Host name="localhost" ...>
                      ...
                      <Valve className="org.apache.catalina.valves.RemoteHostValve"
                      allow="*.mycompany.com,www.yourcompany.com"/>
                      <Valve className="org.apache.catalina.valves.RemoteAddrValve"
                      deny="192.168.1.*"/>
                      ...
                      </Host>

          這是我們服務(wù)器的配置,具體文件不能給你,因?yàn)樯婕暗焦緳C(jī)密,所以那一行我給你,我拷貝下來了

          JAVA_OPTS='-server -Xms512m -Xmx768m -XX:NewSize=128m -XX:MaxNewSize=192m -XX:SurvivorRatio=8'

          posted on 2007-07-03 15:37 前方的路 閱讀(731) 評論(0)  編輯  收藏 所屬分類: Web應(yīng)用服務(wù)器
          主站蜘蛛池模板: 平江县| 武定县| 浦江县| 大宁县| 新巴尔虎左旗| 正阳县| 安乡县| 陵水| 麟游县| 奉新县| 古丈县| 巫溪县| 荣成市| 普洱| 易门县| 肥城市| 恭城| 筠连县| 东乌珠穆沁旗| 夏津县| 邯郸县| 开封市| 隆子县| 秀山| 丰城市| 龙门县| 奇台县| 峡江县| 资溪县| 湖南省| 南江县| 韩城市| 全州县| 文化| 清徐县| 巴林右旗| 新郑市| 柏乡县| 疏附县| 射洪县| 兰溪市|