Tomcat配置文件詳解

/export/servers/tomcat7/conf/server.xml

裏面很多都是註釋:

我們先來看看各個組件之間的關係:

server.xml文件中可定義的元素非常多,知道以上的就足夠了!

下面來說說常用組件:

1. Server組件:

   文本式例:

   <Server port="8005" shutdown="SHUTDOWN">

   <Listener className="org.apache.catalina.startup.VersionLoggerListener" />

   

   一個tomcat會啓動一個server實例,(即jvm(java虛擬機)),它監聽8005端口一接受shutdown命令;各個Server的定義不能使用同一個端口,多實例,需要使用不用Server的端口!

   Server相關屬性:

  • className: 用於實現此Server容器的完全限定類的名稱,默認就行

  • port: 接收shutdown指令的端口,默認僅允許通過本機訪問,默認爲8005;

  • shutdown:發往此Server用於實現關閉tomcat實例的命令字符串,默認爲SHUTDOWN;

2.Service組件:

   文本式例:

   <Service name="Catalina">

   Service主要用於關聯一個引擎和與此引擎相關的連接器,每個連接器通過一個特定的端口和協議接收入站請求交將其轉發至關聯的引擎進行處理。因此,Service要包含一個引擎、一個或多個連接器。

   這定義了一個名爲Catalina的Service,此名字也會在產生相關的日誌信息時記錄在日誌文件當中。

   Service相關的屬性:

  • className: 用於實現service的類名,一般都是org.apache.catalina.core.StandardService。

  • name:此服務的名稱,默認爲Catalina;

3.Connector組件:

   進入Tomcat的請求可以根據Tomcat的工作模式分爲如下兩類:

  • Tomcat作爲應用程序服務器:請求來自於前端的web服務器,這可能是Apache, IIS, Nginx等;

  • Tomcat作爲獨立服務器:請求來自於web瀏覽器;

Tomcat應該考慮工作情形併爲相應情形下的請求分別定義好需要的連接器才能正確接收來自於客戶端的請求。一個引擎可以有一個或多個連接器,以適應多種請求方式。

定義連接器可以使用多種屬性,有些屬性也只適用於某特定的連接器類型。一般說來,常見於server.xml中的連接器類型通常有4種:

  • HTTP連接器

  • SSL連接器

  • AJP 1.3連接器

  • proxy連接器

如上面示例server.xml中定義的HTTP連接器:

   <Connector port="8080" protocol="HTTP/1.1" connectionTimeout="20000" redirectPort="8443" URIEncoding="utf-8" useBodyEncodingForURI="true" maxThreads="1000" maxSpareThreads="750" minSpareThreads="50" />

   定義連接器時可以配置的屬性非常多,但通常定義HTTP連接器時必須定義的屬性只有“port”,定義AJP連接器時必須定義的屬性只有"protocol",因爲默認的協議爲HTTP。以下爲常用屬性的說明:

  • address:指定連接器監聽的地址,默認爲所有地址,即0.0.0.0;

  • maxThreads:支持的最大併發連接數,默認爲200;

  • port:監聽的端口,默認爲0;

  • protocol:連接器使用的協議,默認爲HTTP/1.1,定義AJP協議時通常爲AJP/1.3;

  • redirectPort:如果某連接器支持的協議是HTTP,當接收客戶端發來的HTTPS請求時,則轉發至此屬性定義的端口;

  • connectionTimeout:等待客戶端發送請求的超時時間,單位爲毫秒,默認爲60000,即1分鐘;

  • enableLookups:是否通過request.getRemoteHost()進行DNS查詢以獲取客戶端的主機名;默認爲true;

  • acceptCount:設置等待隊列的最大長度;通常在tomcat所有處理線程均處於繁忙狀態時,新發來的請求將被放置於等待隊列中;

  • maxSpareThreads:最大備用線程數,一旦創建的線程超過這個值,Tomcat就會關閉不再需要的socket線程。

   下面是一個定義了多個屬性的SSL連接器:

   <Connector port="8443" maxThreads="150" minSpareThreads="25" maxSpareThreads="75" enableLookups="false" acceptCount="100" debug="0" scheme="https" secure="true" clientAuth="false" sslProtocol="TLS" />

4.Engine組件:

   Engine是Servlet處理器的一個實例,即servlet引擎,默認爲定義在server.xml中的Catalina。Engine需要defaultHost屬性來爲其定義一個接收所有發往非明確定義虛擬主機的請求的host組件。如前面示例中定義的:

<Engine name="Catalina" defaultHost="localhost">

常用的屬性定義:

  • defaultHost:Tomcat支持基於FQDN的虛擬主機,這些虛擬主機可以通過在Engine容器中定義多個不同的Host組件來實現;但如果此引擎的連接器收到一個發往非非明確定義虛擬主機的請求時則需要將此請求發往一個默認的虛擬主機進行處理,因此,在Engine中定義的多個虛擬主機的主機名稱中至少要有一個跟defaultHost定義的主機名稱同名;

  • name:Engine組件的名稱,用於日誌和錯誤信息記錄時區別不同的引擎;

注,Engine容器中可以包含Realm、Host、Listener和Valve子容器。

5. Host組件

位於Engine容器中用於接收請求並進行相應處理的主機或虛擬主機,如前面默認配置文件中定義:

<Host name="localhost"  appBase="webapps"

           unpackWARs="true" autoDeploy="true">

</Host>

常用屬性說明:

  • appBase:此Host的webapps目錄,即存放非歸檔的web應用程序的目錄或歸檔後的WAR文件的目錄路徑;可以使用基於$CATALINA_HOME的相對路徑;

  • autoDeploy:在Tomcat處於運行狀態時放置於appBase目錄中的應用程序文件是否自動進行deploy;默認爲true;

  • unpackWars:在啓用此webapps時是否對WAR格式的歸檔文件先進行展開;默認爲true;

新增加一個虛擬主機:

   <Host name="www.123.com"  appBase="/export/App"

               unpackWARs="false" autoDeploy="true" xmlValidation="false" xmlNamespaceAware="false" >

           <Context path="" docBase="./aaa" debug="0" reloadable="true" crossContext="true"/>

   </Host>

6.Context組件:

   Context在某些意義上類似於apache中的路徑別名,一個Context定義用於標識tomcat實例中的一個Web應用程序;如下面的定義:

   <Context path="" docBase="./aaa" debug="0" reloadable="true" crossContext="true"/>

   在Tomcat中,每一個context定義也可以使用一個單獨的XML文件進行,其文件的目錄爲$CATALINA_HOME/conf/<engine name>/<host name>。即(/export/servers/tomcat7/conf/Catalina/localhost),啓動tomcat,engine_name和host_name就可以生效!可以用於Context中的XML元素有Loader,Manager,Realm,Resources和WatchedResource。

   [root@localhost localhost]# cat ROOT.xml

   <?xml version="1.0" encoding="UTF-8"?>

   <Context path="/" docBase="/export/App/aaa">

   </Context>

wKioL1lHeYCCGD0eAAAlj-jDo3A691.png

   常用的定義有:

  • docBase:相應的Web應用程序的存放位置;也可以使用相對路徑,起始路徑爲此Context所屬Host中appBase定義的路徑;切記,docBase的路徑名不能與相應的Host中appBase中定義的路徑名有包含關係,比如,如果appBase爲deploy,而docBase絕不能爲deploy-bbs類的名字;我們在項目中常用這個作用項目發佈目錄,不用appBase,host中的name是基於域名就行設置虛擬主機的,docBase,如果是絕對路徑,就是項目目錄,如果是相對路徑,就是appBase+docBase, path代表的是url

  • path:相對於Web服務器根路徑而言的URI;如果爲空“”,則表示爲此webapp的根路徑;如果context定義在一個單獨的xml文件中,此屬性不需要定義;

  • reloadable:是否允許重新加載此context相關的Web應用程序的類;默認爲false;

7.Realm組件

   一個Realm表示一個安全上下文,它是一個授權訪問某個給定Context的用戶列表和某用戶所允許切換的角色相關定義的列表。因此,Realm就像是一個用戶和組相關的數據庫。定義Realm時惟一必須要提供的屬性是classname,它是Realm的多個不同實現,用於表示此Realm認證的用戶及角色等認證信息的存放位置。

   <Realm className="org.apache.catalina.realm.UserDatabaseRealm" resourceName="UserDatabase"/>

(8).Valve組件

Valve類似於過濾器,它可以工作於Engine和Host/Context之間、Host和Context之間以及Context和Web應用程序的某資源之間。一個容器內可以建立多個Valve,而且Valve定義的次序也決定了它們生效的次序。Tomcat中實現了多種不同的Valve:

  • AccessLogValve:訪問日誌Valve

  • ExtendedAccessValve:擴展功能的訪問日誌Valve

  • JDBCAccessLogValve:通過JDBC將訪問日誌信息發送到數據庫中;

  • RequestDumperValve:請求轉儲Valve;

  • RemoteAddrValve:基於遠程地址的訪問控制;

  • RemoteHostValve:基於遠程主機名稱的訪問控制;

  • SemaphoreValve:用於控制Tomcat主機上任何容器上的併發訪問數量;

  • JvmRouteBinderValve:在配置多個Tomcat爲以Apache通過mod_proxy或mod_jk作爲前端的集羣架構中,當期望停止某節點時,可以通過此Valve將用記請求定向至備用節點;使用此Valve,必須使用JvmRouteSessionIDBinderListener;

  • ReplicationValve:專用於Tomcat集羣架構中,可以在某個請求的session信息發生更改時觸發session數據在各節點間進行復制;

  • SingleSignOn:將兩個或多個需要對用戶進行認證webapp在認證用戶時連接在一起,即一次認證即可訪問所有連接在一起的webapp;

  • ClusterSingleSingOn:對SingleSignOn的擴展,專用於Tomcat集羣當中,需要結合ClusterSingleSignOnListener進行工作;

RemoteHostValve和RemoteAddrValve可以分別用來實現基於主機名稱和基於IP地址的訪問控制,控制本身可以通過allow或deny來進行定義,這有點類似於Apache的訪問控制功能;如下面的Valve則實現了僅允許本機訪問/probe:

1
2
3
4
allow="127\.0\.0\.1"/>

其中相關屬性定義有:

  • className:相關的java實現的類名,相應於分別應該爲org.apache.catalina.valves.RemoteHostValve或org.apache.catalina.valves.RemoteAddrValve;

  • allow:以逗號分開的允許訪問的IP地址列表,支持正則表達式,因此,點號“.”用於IP地址時需要轉義;僅定義allow項時,非明確allow的地址均被deny;

  • deny: 以逗號分開的禁止訪問的IP地址列表,支持正則表達式;使用方式同allow;

(9).GlobalNamingResources

應用於整個服務器的JNDI映射,此可以避免每個Web應用程序都需要在各自的web.xml創建,這在web應用程序以WAR的形式存在時尤爲有用。它通常可以包含三個子元素:

  • Environment;

  • Resource;

  • ResourceEnvRef;

(10).WatchedResource

WatchedResource可以用於Context中監視指定的webapp程序文件的改變,並且能夠在監視到文件內容發生改變時重新裝載此文件。

(11).Listener

Listener用於創建和配置LifecycleListener對象,而LifecycleListener通常被開發人員用來創建和刪除容器。

(12).Loader

Java的動態裝載功能是其語言功能強大表現之一,Servlet容器使用此功能在運行時動態裝載servlet和它們所依賴的類。Loader可以用於Context中控制java類的加載。

(13).Manager

Manger對象用於實現HTTP會話管理的功能,Tomcat中有5種Manger的實現:

1) StandardManager

Tomcat的默認會話管理器,用於非集羣環境中對單個處於運行狀態的Tomcat實例會話進行管理。當Tomcat關閉時,這些會話相關的數據會被寫入磁盤上的一個名叫SESSION.ser的文件,並在Tomcat下次啓動時讀取此文件。

2) PersistentManager

當一個會話長時間處於空閒狀態時會被寫入到swap會話對象,這對於內存資源比較吃緊的應用環境來說比較有用。

3)DeltaManager

用於Tomcat集羣的會話管理器,它通過將改變了會話數據同步給集羣中的其它節點實現會話複製。這種實現會將所有會話的改變同步給集羣中的每一個節點,也是在集羣環境中用得最多的一種實現方式。

4) BackupManager

用於Tomcat集羣的會話管理器,與DeltaManager不同的是,某節點會話的改變只會同步給集羣中的另一個而非所有節點。

5)SimpleTcpReplicationManager

Tomcat4時用到的版本,過於老舊了。

(14).Stores

PersistentManager必須包含一個Store元素以指定將會話數據存儲至何處。這通常有兩種實現方式:FileStore和JDBCStore。

(15).Resources

經常用於實現在Context中指定需要裝載的但不在Tomcat本地磁盤上的應用資源,如Java類,HTML頁面,JSP文件等。

(16).Cluster

專用於配置Tomcat集羣的元素,可用於Engine和Host容器中。在用於Engine容器中時,Engine中的所有Host均支持集羣功能。在Cluster元素中,需要直接定義一個Manager元素,這個Manager元素有一個其值爲org.apache.catalina.ha.session.DeltaManager或org.apache.catalina.ha.session.BackupManager的className屬性。同時,Cluster中還需要分別定義一個Channel和ClusterListener元素。

  • Channel 用於Cluster中給集羣中同一組中的節點定義通信“信道”。Channel中需要至少定義Membership、Receiver和Sender三個元素,此外還有一個可選元素Interceptor。

  • Membership 用於Channel中配置同一通信信道上節點集羣組中的成員情況,即監控加入當前集羣組中的節點並在各節點間傳遞心跳信息,而且可以在接收不到某成員的心跳信息時將其從集羣節點中移除。Tomcat中Membership的實現是org.apache.catalina.tribes.membership.McastService。

  • Sender 用於Channel中配置“複製信息”的發送器,實現發送需要同步給其它節點的數據至集羣中的其它節點。發送器不需要屬性的定義,但可以在其內部定義一個Transport元素。

  • Transport 用於Sender內部,配置數據如何發送至集羣中的其它節點。Tomcat有兩種Transport的實現:

1) PooledMultiSender

基於Java阻塞式IO,可以將一次將多個信息併發發送至其它節點,但一次只能傳送給一個節點。

2)PooledParallelSener

基於Java非阻塞式IO,即NIO,可以一次發送多個信息至一個或多個節點。

  • Receiver 用於Channel定義某節點如何從其它節點的Sender接收復制數據,Tomcat中實現的接收方式有兩種BioReceiver和NioReceiver。

3.web.xml

web.xml基於Java Servlet規範,可被用於每一個Java servlet容器,通常有兩個存放位置,$CATALINA_BASE/conf和每個Web應用程序(通常是WEB-INF/web.xml)。Tomcat在deploy一個應用程序時(包括重啓或重新載入),它首先讀取conf/web.xml,而後讀取WEB-INF/web.xml。

好了,到這裏Tomcat服務器的安裝與配置以及各組件詳解就說到這裏了,希望大家有所收穫^_^…… 在前面的兩篇博客中我們主要講解了,Tomcat相關的理論知識與相關組件的講解,從下一篇博客開始,我們將講解Tomcat的相關操作,包括Nginx結合Tomcat、Apache結合Tomcat、Tomcat集羣講解等。


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章