Tomcat 的內(nèi)存配置及優(yōu)化_第1頁(yè)
Tomcat 的內(nèi)存配置及優(yōu)化_第2頁(yè)
Tomcat 的內(nèi)存配置及優(yōu)化_第3頁(yè)
Tomcat 的內(nèi)存配置及優(yōu)化_第4頁(yè)
全文預(yù)覽已結(jié)束

下載本文檔

版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡(jiǎn)介

1、Tomcat的內(nèi)存配置及優(yōu)化Tomcat本身不能直接在計(jì)算機(jī)上運(yùn)行,需要依賴于硬件基礎(chǔ)之上的操作系統(tǒng)和一個(gè)java 虛擬機(jī)。你能選擇自己的需要選擇不同的操作系統(tǒng)和對(duì)應(yīng)的JDK的版本(只要是符合Sun 發(fā)布的Java規(guī)范的),但我們推薦你使用Sun公司發(fā)布的JDK。確保你所使用的版本是最新 的,因?yàn)镾un公司和其他一些公司一直在為提高性能而對(duì)java虛擬機(jī)做一些升級(jí)改進(jìn)。一 些報(bào)告顯示JDK1.4在性能上比JDK1.3提高了將近10%到20%。能給Java虛擬機(jī)設(shè)置使用的內(nèi)存,不過如果你的選擇不對(duì)的話,虛擬機(jī)不會(huì)補(bǔ)償???通過命令行的方式改動(dòng)虛擬機(jī)使用內(nèi)存的大小。如下表所示有兩個(gè)參數(shù)用來(lái)設(shè)置虛擬

2、機(jī)使用 內(nèi)存的大小。參數(shù)描述-XmsJVM初始化堆的大小-XmxJVM堆的最大值這兩個(gè)值的大小一般根據(jù)需要進(jìn)行設(shè)置。初始化堆的大小執(zhí)行了虛擬機(jī)在啟動(dòng)時(shí)向系統(tǒng) 申請(qǐng)的內(nèi)存的大小。一般而言,這個(gè)參數(shù)不重要。不過有的應(yīng)用程式在大負(fù)載的情況下會(huì)急 劇地占用更多的內(nèi)存,此時(shí)這個(gè)參數(shù)就是顯得非常重要,如果虛擬機(jī)啟動(dòng)時(shí)設(shè)置使用的內(nèi)存 比較小而在這種情況下有許多對(duì)象進(jìn)行初始化,虛擬機(jī)就必須重復(fù)地增加內(nèi)存來(lái)滿足使用。 由于這種原因,我們一般把-Xms 和-Xmx設(shè)為相同大,而堆的最大值受限于系統(tǒng)使用的物理 內(nèi)存。一般使用數(shù)據(jù)量較大的應(yīng)用程式會(huì)使用持久對(duì)象,內(nèi)存使用有可能迅速地增長(zhǎng)。當(dāng)應(yīng) 用程式需要的內(nèi)存超出堆的

3、最大值時(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)大。視窗系統(tǒng)下,在文件/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ī)制。虛

4、擬機(jī)的堆大小決定了虛擬機(jī)花費(fèi)在收 集垃圾上的時(shí)間和頻度。收集垃圾能接受的速度和應(yīng)用有關(guān),應(yīng)該通過分析實(shí)際的垃圾收集 的時(shí)間和頻率來(lái)調(diào)整。如果堆的大小非常大,那么完全垃圾收集就會(huì)非常慢,不過頻度會(huì)降 低。如果你把堆的大小和內(nèi)存的需要一致,完全收集就非常快,不過會(huì)更加頻繁。調(diào)整堆大 小的的目的是最小化垃圾收集的時(shí)間,以在特定的時(shí)間內(nèi)最大化處理客戶的請(qǐng)求。在基準(zhǔn)測(cè) 試的時(shí)候,為確保最佳的性能,要把堆的大小設(shè)大,確保垃圾收集不在整個(gè)基準(zhǔn)測(cè)試的過程 中出現(xiàn)。如果系統(tǒng)花費(fèi)非常多的時(shí)間收集垃圾,請(qǐng)減小堆大小。一次完全的垃圾收集應(yīng)該不超過 3-5秒。如果垃圾收集成為瓶頸,那么需要指定代的大小,檢查垃圾收集的周

5、詳輸出,研究 垃圾收集參數(shù)對(duì)性能的影響。一般說(shuō)來(lái),你應(yīng)該使用物理內(nèi)存的80%作為堆大小。當(dāng)增加 處理器時(shí),記得增加內(nèi)存,因?yàn)榉峙淠懿⑿羞M(jìn)行,而垃圾收集不是并行的。Tomcat 5常用優(yōu)化和設(shè)置1、JDK內(nèi)存優(yōu)化:Tomcat默認(rèn)能使用的內(nèi)存為128MB,視窗系統(tǒng)下,在文件tomcat_home/bin/catalina.bat,Unix下,在文件tomcat_home/bin/catalina.sh的前面,增加如下設(shè)置:JAVA_OPTS= -Xms初始化內(nèi)存大小-Xmx能使用的最大內(nèi)存一般說(shuō)來(lái),你應(yīng)該使用物理內(nèi)存的80%作為堆大小。2、連接器優(yōu)化:在tomcat設(shè)置文件server.xml中

6、的設(shè)置中,和連接數(shù)相關(guān)的參數(shù)有:maxThreads:Tomcat使用線程來(lái)處理接收的每個(gè)請(qǐng)求。這個(gè)值表示Tomcat可創(chuàng)建的最大的線程數(shù)。 默認(rèn)值200。acceptCount:指定當(dāng)所有能使用的處理請(qǐng)求的線程數(shù)都被使用時(shí),能放到處理隊(duì)列中的請(qǐng)求數(shù),超過 這個(gè)數(shù)的請(qǐng)求將不予處理。默認(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è)置為falseconnnect

7、ionTimeout:網(wǎng)絡(luò)連接超時(shí),默認(rèn)值60000,單位:毫秒。設(shè)置為0表示永不超時(shí),這樣設(shè)置有隱患 的。通??稍O(shè)置為30000毫秒。maxKeepAliveRequests:保持請(qǐng)求數(shù)量,默認(rèn)值100。bufferSize:輸入流緩沖大小,默認(rèn)值2048 pression:壓縮傳輸,取值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è)置, 通常視窗系統(tǒng)是2000個(gè)左右,Linux是1000個(gè)左右。3

8、、tomcat中怎么禁止和允許列目錄下的文件在tomcat_home/conf/web.xml 中,把 listings 參數(shù)設(shè)置成 false 即可,如下:.listingsfalse.4、tomcat中怎么禁止和允許主機(jī)或IP地址訪問 .這是服務(wù)器的設(shè)置:JAVA_OPTS=-server -Xms512m -Xmx768m -XX:NewSize=128m -XX:MaxNewSize=192m -XX:SurvivorRatio=8-Xms512m /JVM占用最小內(nèi)存-Xmx768m /JVM占用最大內(nèi)存-XX:PermSize=128m 最小堆大小-XX:MaxPermSize=1

9、92m /最大堆大小tomcat server.xml Connector 配置Tomcat初始化時(shí)創(chuàng)建的線程數(shù)。默認(rèn)值4。如果當(dāng)前沒有空閑線程,且沒有超過maxThreads,一次性創(chuàng)建的空閑線程數(shù)量。Tomcat初始化時(shí)創(chuàng)建的線程數(shù)量也由此值設(shè)置。maxSpareThreads=75- 一旦創(chuàng)建的線程超過這個(gè)值,Tomcat就會(huì)關(guān)閉不再需要的socket線程。默認(rèn)值50。一旦創(chuàng)建的線程超過此數(shù)值,Tomcat會(huì)關(guān)閉不再需要的線程。線程數(shù)可以大致上用“同時(shí)在線人數(shù)*每秒用戶操作次數(shù)*系統(tǒng)平均操作時(shí)間”來(lái)計(jì)算。enableLookups=false-是否反查域名,默認(rèn)值為 true。為了提高處

10、理能力,應(yīng)設(shè)置為falseredirectPort=8443acceptCount=100-指定當(dāng)所有可以使用的處理請(qǐng)求的線程數(shù)都被使用時(shí),可以放到處理隊(duì)列中的請(qǐng)求數(shù),超過這個(gè)數(shù)的請(qǐng)求將不予處理。默認(rèn)值10。如果當(dāng)前可用線程數(shù)為0,則將請(qǐng)求放入處理隊(duì)列中。這個(gè)值限定了請(qǐng)求隊(duì)列的大小,超過這個(gè)數(shù)值的請(qǐng)求將不予處理。connectionTimeout=20000-網(wǎng)絡(luò)連接超時(shí),默認(rèn)值20000,單位:毫秒。設(shè)置為0表示永不超時(shí), 這樣設(shè)置有隱患的。通常可設(shè)置為30000毫秒。(本系統(tǒng)由于與后臺(tái)系統(tǒng)接口超時(shí)時(shí)間較長(zhǎng),使用設(shè)置為60000)錯(cuò)誤原因:Mysql服務(wù)器默認(rèn)的“wait_timeout”是8小時(shí),也就是說(shuō)一個(gè)connection空閑超過8 個(gè)小時(shí),Mysql將自動(dòng)斷開該connection。這就是問題的所在,在C3P0 pools中的connections 如果空閑超過8小時(shí),Mysql將其斷開,而C3P0并不知道該connection已經(jīng)失效,如果這 時(shí)有Client請(qǐng)求connection,C3P0將該失效的Connection提供給Client,將會(huì)

溫馨提示

  • 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。

評(píng)論

0/150

提交評(píng)論