Tomcat 服務(wù)器核心配置詳解

首先看兩個(gè)問題

  • 問題一:去哪兒配置? 核心配置在tomcat目錄下conf/server.xml文件
  • 問題二∶怎么配置?
    注意∶
  • Tomcat作為服務(wù)器的配置,主要是 server.xml文件的配置;
  • server.xml中包含了Servlet容器的相關(guān)配置,即Catalina的配置;
  • Xml 文件的講解主要是標(biāo)簽的使用

主要標(biāo)簽結(jié)構(gòu)如下:

<!--
    Server 根元素,創(chuàng)建?個(gè)Server實(shí)例,?標(biāo)簽有 Listener、GlobalNamingResources、
    Service
-->
<Server>
    <!--定義監(jiān)聽器-->
    <Listener/>
    <!--定義服務(wù)器的全局JNDI資源 -->
    <GlobalNamingResources/>
    <!--
        定義?個(gè)Service服務(wù),?個(gè)Server標(biāo)簽可以有多個(gè)Service服務(wù)實(shí)例
    -->
    <Service/>
</Server>
server.xml
<!--
    port:關(guān)閉服務(wù)器的監(jiān)聽端?
    shutdown:關(guān)閉服務(wù)器的指令字符串
-->
<Server port="8005" shutdown="SHUTDOWN">
    <!-- 以日志形式輸出服務(wù)器 、操作系統(tǒng)、JVM的版本信息 -->
    <Listener className="org.apache.catalina.startup.VersionLoggerListener" />
    <!-- Security listener. Documentation at /docs/config/listeners.html
    <Listener className="org.apache.catalina.security.SecurityListener" />
    -->
    <!--APR library loader. Documentation at /docs/apr.html -->
    <!-- 加載(服務(wù)器啟動) 和 銷毀 (服務(wù)器停止) APR。 如果找不到APR庫, 則會輸出日志, 并
    不影響 Tomcat啟動 -->
    <Listener className="org.apache.catalina.core.AprLifecycleListener"
    SSLEngine="on" />
    <!-- Prevent memory leaks due to use of particular java/javax APIs-->
    <!-- 避免JRE內(nèi)存泄漏問題 -->
    <Listener
    className="org.apache.catalina.core.JreMemoryLeakPreventionListener" />
    <!-- 加載(服務(wù)器啟動) 和 銷毀(服務(wù)器停止) 全局命名服務(wù) -->
    <Listener
    className="org.apache.catalina.mbeans.GlobalResourcesLifecycleListener" />
    <!-- 在Context停?時(shí)重建 Executor 池中的線程, 以避免ThreadLocal 相關(guān)的內(nèi)存泄漏 -->
    <Listener
    className="org.apache.catalina.core.ThreadLocalLeakPreventionListener" />


    <!-- Global JNDI resources
         Documentation at /docs/jndi-resources-howto.html
         GlobalNamingResources 中定義了全局命名服務(wù)
    -->
    <GlobalNamingResources>
    <!-- Editable user database that can also be used by
         UserDatabaseRealm to authenticate users
    -->
    <Resource name="UserDatabase" auth="Container"
    type="org.apache.catalina.UserDatabase"
    description="User database that can be updated and saved"
    factory="org.apache.catalina.users.MemoryUserDatabaseFactory"
    pathname="conf/tomcat-users.xml" />
    </GlobalNamingResources>
    <!-- A "Service" is a collection of one or more "Connectors" that share
         a single "Container" Note: A "Service" is not itself a "Container",
         so you may not define subcomponents such as "Valves" at this level.
         Documentation at /docs/config/service.html
    -->
    <Service name="Catalina">
        ...
    </Service>
</Server>
Service 標(biāo)簽
<!--
    該標(biāo)簽?于創(chuàng)建 Service 實(shí)例,默認(rèn)使? org.apache.catalina.core.StandardService。
    默認(rèn)情況下,Tomcat 僅指定了Service 的名稱, 值為 "Catalina"。
    Service ?標(biāo)簽為 : Listener、Executor、Connector、Engine,
    其中:
        Listener ?于為Service添加?命周期監(jiān)聽器,
        Executor ?于配置Service 共享線程池,
        Connector ?于配置Service 包含的鏈接器,
        Engine ?于配置Service中鏈接器對應(yīng)的Servlet 容器引擎
-->
<Service name="Catalina">
    ...
</Service>

Executor 標(biāo)簽

<!--
    默認(rèn)情況下,Service   并未添加共享線程池配置。如果我們想添加?個(gè)線程池,可以在
<Service> 下添加如下配置:
    name:線程池名稱,用于Connector中指定
    namePrefix:所創(chuàng)建的每個(gè)線程的名稱前綴,一個(gè)單獨(dú)的線程名稱為 namePrefix+threadNumber
    maxThreads:池中最大線程數(shù)
    minSpareThreads:活躍線程數(shù),也就是核?池線程數(shù),這些線程不會被銷毀,會一直存在
    maxIdleTime:線程空閑時(shí)間,超過該時(shí)間后,空閑線程會被銷毀,默認(rèn)值為6000(1分鐘),單位毫秒
    maxQueueSize:在被執(zhí)行前最大線程排隊(duì)數(shù)目,默認(rèn)為Int的最大值,也就是廣義的無限。除非特
殊情況,這個(gè)值不需要更改,否則會有請求不會被處理的情況發(fā)生
    prestartminSpareThreads:啟動線程池時(shí)是否啟動minSpareThreads部分線程。默認(rèn)值為false,即不啟動
    threadPriority:線程池中線程優(yōu)先級,默認(rèn)值為5,值從1到10
    className:線程池實(shí)現(xiàn)類,未指定情況下,默認(rèn)實(shí)現(xiàn)類為  
org.apache.catalina.core.StandardThreadExecutor。如果想使用自定義線程池首先需要實(shí)現(xiàn)
org.apache.catalina.Executor接口
-->
<Executor   name="commonThreadPool"
    namePrefix="thread-exec-"
    maxThreads="200"
    minSpareThreads="100"
    maxIdleTime="60000"
    maxQueueSize="Integer.MAX_VALUE"
    prestartminSpareThreads="false"
    threadPriority="5"
    className="org.apache.catalina.core.StandardThreadExecutor"/>

Connector 標(biāo)簽
Connector 標(biāo)簽用于創(chuàng)建鏈接器實(shí)例
默認(rèn)情況下,server.xml配置了兩個(gè)連接器,一個(gè)支持HTP協(xié)議,一個(gè)支持APJ協(xié)議大多數(shù)情況下,我們并不需要新增連接器配置,只是根據(jù)需要對已有連接器進(jìn)行優(yōu)化

<!--
port:
    端?號,Connector用于創(chuàng)建服務(wù)端Socket并進(jìn)行監(jiān)聽,以等待客戶端請求鏈接。如果該屬性設(shè)置
為0,Tomcat將會隨機(jī)選擇一個(gè)可用的端口號給當(dāng)前Connector使用
protocol:
    當(dāng)前Connector支持的訪問協(xié)議。默認(rèn)為  HTTP/1.1,并采用自動切換機(jī)制選擇一個(gè)基于JAVA NIO的連接器或者基于本地APR的鏈接器(根據(jù)本地是否含有Tomcat的本地庫判定)
connectionTimeOut:
Connector   接收鏈接后的等待超時(shí)時(shí)間,單位為毫秒。-1表示不超時(shí)。
redirectPort:
    當(dāng)前Connector不支持SSL請求,接收到了一個(gè)請求,并且也符合security-constraint   約束,
需要SSL傳輸,Catalina自動將請求重定向到指定的端口。
executor:
    指定共享線程池的名稱,也可以通過maxThreads、minSpareThreads  等屬性配置內(nèi)部線程池。
URIEncoding:
    用于指定編碼URI的字符編碼, Tomcat8.x版本默認(rèn)的編碼為UTF-8  ,Tomcat7.x版本默認(rèn)為ISO-8859-1
-->
<!--org.apache.coyote.http11.Http11NioProtocol  ,非阻塞式Java NIO 連接器-->
<Connector  port="8080" protocol="HTTP/1.1" connectionTimeout="20000"
redirectPort="8443" />
<Connector  port="8009" protocol="AJP/1.3"  redirectPort="8443" />

可以使用共享線程池

<Connector  port="8080" 
    protocol="HTTP/1.1"
    executor="commonThreadPool"
    maxThreads="1000"   
    minSpareThreads="100"   
    acceptCount="1000"  
    maxConnections="1000"   
    connectionTimeout="20000"
    compression="on"    
    compressionMinSize="2048"   
    disableUploadTimeout="true" 
    redirectPort="8443" 
    URIEncoding="UTF-8" />

Engine 標(biāo)簽
Engine 表示 Servlet 引擎

<!--
name:用于指定Engine 的名稱, 默認(rèn)為Catalina
defaultHost:默認(rèn)使用的虛擬主機(jī)名稱,當(dāng)客戶端請求指向的主機(jī)?效時(shí),將交由默認(rèn)的虛擬主機(jī)處理, 默認(rèn)為localhost
-->
<Engine name="Catalina" defaultHost="localhost">
    ...
</Engine>

Host 標(biāo)簽
Host 標(biāo)簽用于配置一個(gè)虛擬主機(jī)

<Host name="localhost" appBase="webapps" unpackWARs="true" autoDeploy="true">
    ...
</Host>

Context 標(biāo)簽
Context 標(biāo)簽用于配置一個(gè)Web應(yīng)用,如下:

<Host name="www.abc.com" appBase="webapps" unpackWARs="true" autoDeploy="true">
<!--
    docBase:Web應(yīng)用目錄或者War包的部署路徑??梢允墙^對路徑,也可以是相對于 Host appBase的相對路徑。
    path:Web應(yīng)用的Context 路徑。如果我們Host名為localhost, 則該web應(yīng)用訪問的根路徑為: 
    http://localhost:8080/web_demo。
-->
    <Context docBase="/Users/yingdian/web_demo" path="/web3"></Context> 
 
    <Valve className="org.apache.catalina.valves.AccessLogValve" directory="logs"
    prefix="localhost_access_log" suffix=".txt"
    pattern="%h %l %u %t &quot;%r&quot; %s %b" />
</Host>
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

友情鏈接更多精彩內(nèi)容