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