1. 程式人生 > >Tomcat學習總結(14)—— Tomcat常見面試題

Tomcat學習總結(14)—— Tomcat常見面試題

一、Tomcat的預設是多少,怎麼修改

Tomcat的預設埠號是8080.

修改Tomcat埠號:

1.找到Tomcat目錄下的conf資料夾

2.進入conf資料夾裡面找到server.xml檔案

3.開啟server.xml檔案

4.在server.xml檔案裡面找到下列資訊

maxThreads=”150″ minSpareThreads=”25″ maxSpareThreads=”75″

enableLookups=”false” redirectPort=”8443″ acceptCount=”100″

connectionTimeout=”20000″ disableUploadTimeout=”true” />

5.把port=”8080″改成port=”8888″,並且儲存

6.啟動Tomcat,並且在IE瀏覽器裡面的位址列輸入http://127.0.0.1:8888/

7、tomcat預設採用的BIO模型,在幾百併發下效能會有很嚴重的下降。tomcat自帶還有NIO的模型,另外也可以呼叫APR的庫來實現作業系統級別控制。

NIO模型是內建的,呼叫很方便,只需要將上面配置檔案中protocol修改成 org.apache.coyote.http11.Http11NioProtocol,重啟即可生效。如下面的引數配置,預設的是HTTP/1.1。

<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″ />

二、tomcat 如何優化?

1、優化連線配置.這裡以tomcat7的引數配置為例,需要修改conf/server.xml檔案,修改連線數,關閉客戶端dns查詢。

引數解釋:

URIEncoding=”UTF-8″ :使得tomcat可以解析含有中文名的檔案的url,真方便,不像apache裡還有搞個mod_encoding,還要手工編譯

maxSpareThreads : 如果空閒狀態的執行緒數多於設定的數目,則將這些執行緒中止,減少這個池中的執行緒總數。

minSpareThreads : 最小備用執行緒數,tomcat啟動時的初始化的執行緒數。

enableLookups : 這個功效和Apache中的HostnameLookups一樣,設為關閉。

connectionTimeout : connectionTimeout為網路連線超時時間毫秒數。

maxThreads : maxThreads Tomcat使用執行緒來處理接收的每個請求。這個值表示Tomcat可建立的最大的執行緒數,即最大併發數。

acceptCount : acceptCount是當執行緒數達到maxThreads後,後續請求會被放入一個等待佇列,這個acceptCount是這個佇列的大小,如果這個佇列也滿了,就直接refuse connection

maxProcessors與minProcessors : 在 Java中執行緒是程式執行時的路徑,是在一個程式中與其它控制執行緒無關的、能夠獨立執行的程式碼段。它們共享相同的地址空間。多執行緒幫助程式設計師寫出CPU最 大利用率的高效程式,使空閒時間保持最低,從而接受更多的請求。

通常Windows是1000個左右,Linux是2000個左右。

useURIValidationHack:

我們來看一下tomcat中的一段原始碼:

【security】

if (connector.getUseURIValidationHack()) {

String uri = validate(request.getRequestURI());

if (uri == null) {

res.setStatus(400);

res.setMessage(“Invalid URI”);

throw new IOException(“Invalid URI”);

} else {

req.requestURI().setString(uri);

// Redoing the URI decoding

req.decodedURI().duplicate(req.requestURI());

req.getURLDecoder().convert(req.decodedURI(), true);

可以看到如果把useURIValidationHack設成”false”,可以減少它對一些url的不必要的檢查從而減省開銷。

enableLookups=”false” : 為了消除DNS查詢對效能的影響我們可以關閉DNS查詢,方式是修改server.xml檔案中的enableLookups引數值。

disableUploadTimeout :類似於Apache中的keeyalive一樣

給Tomcat配置gzip壓縮(HTTP壓縮)功能

compression=”on” compressionMinSize=”2048″

compressableMimeType=”text/html,text/xml,text/javascript,text/css,text/plain”

HTTP 壓縮可以大大提高瀏覽網站的速度,它的原理是,在客戶端請求網頁後,從伺服器端將網頁檔案壓縮,再下載到客戶端,由客戶端的瀏覽器負責解壓縮並瀏覽。相對於普通的瀏覽過程HTML,CSS,Javascript , Text ,它可以節省40%左右的流量。更為重要的是,它可以對動態生成的,包括CGI、PHP , JSP , ASP , Servlet,SHTML等輸出的網頁也能進行壓縮,壓縮效率驚人。

1)compression=”on” 開啟壓縮功能

2)compressionMinSize=”2048″ 啟用壓縮的輸出內容大小,這裡面預設為2KB

3)noCompressionUserAgents=”gozilla, traviata” 對於以下的瀏覽器,不啟用壓縮

4)compressableMimeType=”text/html,text/xml” 壓縮型別

最後不要忘了把8443埠的地方也加上同樣的配置,因為如果我們走https協議的話,我們將會用到8443埠這個段的配置,對吧?

<!–enable tomcat ssl–>

<Connector port=”8443″ 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”

SSLEnabled=”true”

scheme=”https” secure=”true”

clientAuth=”false” sslProtocol=”TLS”

keystoreFile=”d:/tomcat2/conf/shnlap93.jks” keystorePass=”aaaaaa”

/>

好了,所有的Tomcat優化的地方都加上了。

2、優化JDK

Tomcat預設可以使用的記憶體為128MB,Windows下,在檔案{tomcat_home}/bin/catalina.bat,Unix下,在檔案$CATALINA_HOME/bin/catalina.sh的前面,增加如下設定:

JAVA_OPTS=”‘$JAVA_OPTS” -Xms[初始化記憶體大小] -Xmx[可以使用的最大記憶體]

設定環境變數:export JAVA_OPTS=””$JAVA_OPTS” -Xms[初始化記憶體大小] -Xmx[可以使用的最大記憶體]”

一般說來,你應該使用實體記憶體的 80% 作為堆大小。如果本機上有Apache伺服器,可以先折算Apache需要的記憶體,然後修改堆大小。建議設定為70%;建議設定[[初始化記憶體大小]等於[可以使用的最大記憶體],這樣可以減少平凡分配堆而降低效能。

本例使用加入環境變數的方式:

# vi /etc/profile

加入:export JAVA_OPTS=””$JAVA_OPTS” -Xms700 —Xmx700

# source /etc/profile

【引數說明】

-Xms 是指設定程式啟動時佔用記憶體大小。一般來講,大點,程式會啟動的 快一點,但是也可能會導致機器暫時間變慢。

-Xmx 是指設定程式執行期間最大可佔用的記憶體大小。如果程式執行需要佔 用更多的記憶體,超出了這個設定值,就會丟擲OutOfMemory 異常。

-Xss 是指設定每個執行緒的堆疊大小。這個就要依據你的程式,看一個執行緒 大約需要佔用多少記憶體,可能會有多少執行緒同時執行等。

-XX:PermSize設定非堆記憶體初始值,預設是實體記憶體的1/64 。

-XX:MaxPermSize設定最大非堆記憶體的大小,預設是實體記憶體的1/4。

三、tomcat 有那幾種Connector 執行模式?

tomcat的執行模式有3種.修改他們的執行模式.3種模式的執行是否成功,可以看他的啟動控制檯,或者啟動日誌.或者登入他們的預設頁面http://localhost:8080/檢視其中的伺服器狀態。

1)bio

預設的模式,效能非常低下,沒有經過任何優化處理和支援.

2)nio

利用java的非同步io護理技術,no blocking IO技術.

想執行在該模式下,直接修改server.xml裡的Connector節點,修改protocol為

<Connector port=”80″ protocol=”org.apache.coyote.http11.Http11NioProtocol”

connectionTimeout=”20000″

URIEncoding=”UTF-8″

useBodyEncodingForURI=”true”

enableLookups=”false”

redirectPort=”8443″ />

啟動後,就可以生效。

3)apr

安裝起來最困難,但是從作業系統級別來解決非同步的IO問題,大幅度的提高效能.

必須要安裝apr和native,直接啟動就支援apr。下面的修改純屬多餘,僅供大家擴充知識,但仍然需要安裝apr和native

如nio修改模式,修改protocol為org.apache.coyote.http11.Http11AprProtocol