一,Tomcat簡介Tomcat 服務器是一個免費的開放源代碼的Web 應用服務器,Tomcat是Apache 軟件基金會(Apache Software Foundation)的Jakarta 項目中的一個核心項目,它早期的名稱為catalina,后來由Apache、Sun 和其他一些公司及個人共同開發(fā)而成,并更名為Tomcat。Tomcat 是一個小型的輕量級應用服務器,在中小型系統(tǒng)和并發(fā)訪問用戶不是很多的場合下被普遍使用,是開發(fā)和調試JSP 程序的首選,因為Tomcat 技術先進、性能穩(wěn)定,成為目前比較流行的Web 應用服務器。Tomcat是應用(java)服務器,它只是一個servlet容器,是Apache的擴展,但它是獨立運行的。目前最新的版本為Tomcat 8.0.24 Released。 Tomcat不是一個完整意義上的Jave EE服務器,它甚至都沒有提供對哪怕是一個主要Java EE API的實現(xiàn);但由于遵守apache開源協(xié)議,tomcat卻又為眾多的java應用程序服務器嵌入自己的產(chǎn)品中構建商業(yè)的java應用程序服務器,如JBoss和JOnAS。盡管Tomcat對Jave EE API的實現(xiàn)并不完整,然而很企業(yè)也在漸漸拋棄使用傳統(tǒng)的Java EE技術(如EJB)轉而采用一些開源組件來構建復雜的應用。這些開源組件如Structs、Spring和Hibernate,而Tomcat能夠對這些組件實現(xiàn)完美的支持。 Tomcat的架構: Tomcat 6支持Servlet 2.5和JSP 2.1的規(guī)范,它由一組嵌套的層次和組件組成,一般可分為以下四類: 頂級組件:位于配置層次的頂級,并且彼此間有著嚴格的對應關系; 連接器:連接客戶端(可以是瀏覽器或Web服務器)請求至Servlet容器, 容器:包含一組其它組件; 被嵌套的組件:位于一個容器當中,但不能包含其它組件; 各常見組件: 1、服務器(server):Tomcat的一個實例,通常一個JVM只能包含一個Tomcat實例;因此,一臺物理服務器上可以在啟動多個JVM的情況下在每一個JVM中啟動一個Tomcat實例,每個實例分屬于一個獨立的管理端口。這是一個頂級組件。 2、服務(service):一個服務組件通常包含一個引擎和與此引擎相關聯(lián)的一個或多個連接器。給服務命名可以方便管理員在日志文件中識別不同服務產(chǎn)生的日志。一個server可以包含多個service組件,但通常情下只為一個service指派一個server。 連接器類組件: 3、連接器(connectors):負責連接客戶端(可以是瀏覽器或Web服務器)請求至Servlet容器內的Web應用程序,通常指的是接收客戶發(fā)來請求的位置及服務器端分配的端口。默認端口通常是HTTP協(xié)議的8080,管理員也可以根據(jù)自己的需要改變此端口。一個引擎可以配置多個連接器,但這些連接器必須使用不同的端口。默認的連接器是基于HTTP/1.1的Coyote。同時,Tomcat也支持AJP、JServ和JK2連接器。 容器類組件: 4、引擎(Engine):引擎通是指處理請求的Servlet引擎組件,即Catalina Servlet引擎,它檢查每一個請求的HTTP首部信息以辨別此請求應該發(fā)往哪個host或context,并將請求處理后的結果返回的相應的客戶端。嚴格意義上來說,容器不必非得通過引擎來實現(xiàn),它也可以是只是一個容器。如果Tomcat被配置成為獨立服務器,默認引擎就是已經(jīng)定義好的引擎。而如果Tomcat被配置為Apache Web服務器的提供Servlet功能的后端,默認引擎將被忽略,因為Web服務器自身就能確定將用戶請求發(fā)往何處。一個引擎可以包含多個host組件。 5、主機(Host):主機組件類似于Apache中的虛擬主機,但在Tomcat中只支持基于FQDN的“虛擬主機”。一個引擎至少要包含一個主機組件。 6、上下文(Context):Context組件是最內層次的組件,它表示W(wǎng)eb應用程序本身。配置一個Context最主要的是指定Web應用程序的根目錄,以便Servlet容器能夠將用戶請求發(fā)往正確的位置。Context組件也可包含自定義的錯誤頁,以實現(xiàn)在用戶訪問發(fā)生錯誤時提供友好的提示信息。 被嵌套類(nested)組件: 這類組件通常包含于容器類組件中以提供具有管理功能的服務,它們不能包含其它組件,但有些卻可以由不同層次的容器各自配置。 7、閥門(Valve):用來攔截請求并在將其轉至目標之前進行某種處理操作,類似于Servlet規(guī)范中定義的過濾器。Valve可以定義在任何容器類的組件中。Valve常被用來記錄客戶端請求、客戶端IP地址和服務器等信息,這種處理技術通常被稱作請求轉儲(request dumping)。請求轉儲valve記錄請求客戶端請求數(shù)據(jù)包中的HTTP首部信息和cookie信息文件中,響應轉儲valve則記錄響應數(shù)據(jù)包首部信息和cookie信息至文件中。 8、日志記錄器(Logger):用于記錄組件內部的狀態(tài)信息,可被用于除Context之外的任何容器中。日志記錄的功能可被繼承,因此,一個引擎級別的Logger將會記錄引擎內部所有組件相關的信息,除非某內部組件定義了自己的Logger組件。 9、領域(Realm):用于用戶的認證和授權;在配置一個應用程序時,管理員可以為每個資源或資源組定義角色及權限,而這些訪問控制功能的生效需要通過Realm來實現(xiàn)。Realm的認證可以基于文本文件、數(shù)據(jù)庫表、LDAP服務等來實現(xiàn)。Realm的效用會遍及整個引擎或頂級容器,因此,一個容器內的所有應用程序將共享用戶資源。同時,Realm可以被其所在組件的子組件繼承,也可以被子組件中定義的Realm所覆蓋。 引擎(Engine):引擎是指處理請求的Servlet引擎組件,即Catalina Servlet引擎,它從HTTPconnector接收請求并響應請求。它檢查每一個請求的HTTP首部信息以辨別此請求應該發(fā)往哪個host或context,并將請求處理后的結果返回的相應的客戶端。嚴格意義上來說,容器不必非得通過引擎來實現(xiàn),它也可以是只是一個容器。如果Tomcat被配置成為獨立服務器,默認引擎就是已經(jīng)定義好的引擎。而如果Tomcat被配置為Apache Web服務器的提供Servlet功能的后端,默認引擎將被忽略,因為Web服務器自身就能確定將用戶請求發(fā)往何處。一個引擎可以包含多個host組件。 Tomcat連接器架構: 基于Apache做為Tomcat前端的架構來講,Apache通過mod_jk、mod_jk2或mod_proxy模塊與后端的Tomcat進行數(shù)據(jù)交換。而對Tomcat來說,每個Web容器實例都有一個Java語言開發(fā)的連接器模塊組件,在Tomcat6中,這個連接器是org.apache.catalina.Connector類。這個類的構造器可以構造兩種類別的連接器:HTTP/1.1負責響應基于HTTP/HTTPS協(xié)議的請求,AJP/1.3負責響應基于AJP的請求。但可以簡單地通過在server.xml配置文件中實現(xiàn)連接器的創(chuàng)建,但創(chuàng)建時所使用的類根據(jù)系統(tǒng)是支持APR(Apache Portable Runtime)而有所不同。 APR是附加在提供了通用和標準API的操作系統(tǒng)之上一個通訊層的本地庫的集合,它能夠為使用了APR的應用程序在與Apache通信時提供較好伸縮能力時帶去平衡效用。 如果支持APR:
如果不支持APR:
連接器協(xié)議: Tomcat的Web服務器連接器支持兩種協(xié)議:AJP和HTTP,它們均定義了以二進制格式在Web服務器和Tomcat之間進行數(shù)據(jù)傳輸,并提供相應的控制命令。 AJP(Apache JServ Protocol)協(xié)議:目前正在使用的AJP協(xié)議的版本是通過JK和JK2連接器提供支持的AJP13,它基于二進制的格式在Web服務器和Tomcat之間傳輸數(shù)據(jù),而此前的版本AJP10和AJP11則使用文本格式傳輸數(shù)據(jù)。 HTTP協(xié)議:誠如其名稱所表示,其是使用HTTP或HTTPS協(xié)議在Web服務器和Tomcat之間建立通信,此時,Tomcat就是一個完全功能的HTTP服務器,它需要監(jiān)聽在某端口上以接收來自于商前服務器的請求。 二,安裝TomcatTomcat的官方站點為http://tomcat./,要安裝Tomcat,首先需要安裝JDK。 以下安裝平臺為CentOS release 6.6 (Final) 32位平臺上,JDK 版本為jdk-6u45-linux-i586-rpm.bin ,tomcat 使用 apache-tomcat-7.0.63.tar.gz。 1,安裝
三,配置文件詳解Tomcat的配置文件: Tomcat的配置文件默認存放在/usr/local/tomcat/conf目錄中,主要有以下幾個
server.xml: Tomcat的主配置文件,包含Service, Connector, Engine, Realm, Valve, Hosts主組件的相關配置信息; web.xml:遵循Servlet規(guī)范標準的配置文件,用于配置servlet,并為所有的Web應用程序提供包括MIME映射等默認配置信息; tomcat-user.xml:Realm認證時用到的相關角色、用戶和密碼等信息;Tomcat自帶的manager默認情況下會用到此文件;在Tomcat中添加/刪除用戶,為用戶指定角色等將通過編輯此文件實現(xiàn); catalina.policy:Java相關的安全策略配置文件,在系統(tǒng)資源級別上提供訪問控制的能力; catalina.properties:Tomcat內部package的定義及訪問相關的控制,也包括對通過類裝載器裝載的內容的控制;Tomcat6在啟動時會事先讀取此文件的相關設置; logging.properties: Tomcat6通過自己內部實現(xiàn)的JAVA日志記錄器來記錄操作相關的日志,此文件即為日志記錄器相關的配置信息,可以用來定義日志記錄的組件級別以及日志文件的存在位置等; context.xml:所有host的默認配置信息;
Tomcat以面向對象的方式運行,它可以在運行時動態(tài)加載配置文件中定義的對象結構,這有點類似于apache的httpd模塊的調用方式。server.xml中定義的每個主元素都會被創(chuàng)建為對象,并以某特定的層次結構將這些對象組織在一起。下面是個樣樣例配置:
server.xml文件中可定義的元素非常多,包括Server, Service, Connector, Engine, Cluster, Host, Alias, Context, Realm, Valve, Manager, Listener, Resources, Resource, ResourceEnvRef, ResourceLink, WatchedResource, GlobalNameingResources, Store, Transaction, Channel, Membership, Transport, Member, ClusterListener等。 下面簡單介紹幾個常用組件: 1、Server組件 如上面示例文件中定義的: <Server port=”8005” shutdown=”SHUTDOWN”> 這會讓Tomcat6啟動一個server實例(即一個JVM),它監(jiān)聽在8005端口以接收shutdown命令,使用 telnet 連接8005 端口可以直接執(zhí)行 SHUTDOWN 命令來關閉 Tomcat。各Server的定義不能使用同一個端口,這意味著如果在同一個物理機上啟動了多個Server實例,必須配置它們使用不同的端口。這個端口的定義用于為管理員提供一個關閉此實例的便捷途徑,因此,管理員可以直接telnet至此端口使用SHUTDOWN命令關閉此實例。不過,基于安全角度的考慮,這通常不允許遠程進行。 Server的相關屬性: className: 用于實現(xiàn)此Server容器的完全限定類的名稱,默認為org.apache.catalina.core.StandardServer; port: 接收shutdown指令的端口,默認僅允許通過本機訪問,默認為8005; shutdown:發(fā)往此Server用于實現(xiàn)關閉tomcat實例的命令字符串,默認為SHUTDOWN;
Service主要用于關聯(lián)一個引擎和與此引擎相關的連接器,每個連接器通過一個特定的端口和協(xié)議接收入站請求交將其轉發(fā)至關聯(lián)的引擎進行處理。困此,Service要包含一個引擎、一個或多個連接器。 如上面示例中的定義: <Service name=”Catalina”> 這定義了一個名為Catalina的Service,此名字也會在產(chǎn)生相關的日志信息時記錄在日志文件當中。 Service相關的屬性: className: 用于實現(xiàn)service的類名,一般都是org.apache.catalina.core.StandardService。 name:此服務的名稱,默認為Catalina;
進入Tomcat的請求可以根據(jù)Tomcat的工作模式分為如下兩類: Tomcat作為應用程序服務器:請求來自于前端的web服務器,這可能是Apache, IIS, Nginx等; Tomcat作為獨立服務器:請求來自于web瀏覽器; Tomcat應該考慮工作情形并為相應情形下的請求分別定義好需要的連接器才能正確接收來自于客戶端的請求。一個引擎可以有一個或多個連接器,以適應多種請求方式。 定義連接器可以使用多種屬性,有些屬性也只適用于某特定的連接器類型。一般說來,常見于server.xml中的連接器類型通常有4種: 1) HTTP連接器 2) SSL連接器 3) AJP 1.3連接器 4) proxy連接器 如上面示例server.xml中定義的HTTP連接器: <Connector port=”8080″ protocol=”HTTP/1.1″ 定義連接器時可以配置的屬性非常多,但通常定義HTTP連接器時必須定義的屬性只有“port“,定義AJP連接器時必須定義的屬性只有”protocol”,因為默認的協(xié)議為HTTP。以下為常用屬性的說明: 1) address:指定連接器監(jiān)聽的地址,默認為所有地址,即0.0.0.0; 可以自己指定地,如 2) maxThreads:支持的最大并發(fā)連接數(shù),默認為200; 3) port:監(jiān)聽的端口,默認為0; 4) protocol:連接器使用的協(xié)議,默認為HTTP/1.1,定義AJP協(xié)議時通常為AJP/1.3; 5) redirectPort:如果某連接器支持的協(xié)議是HTTP,當接收客戶端發(fā)來的HTTPS請求時,則轉發(fā)至此屬性定義的端口; 6) connectionTimeout:等待客戶端發(fā)送請求的超時時間,單位為毫秒,默認為60000,即1分鐘; 7) enableLookups:是否通過request.getRemoteHost()進行DNS查詢以獲取客戶端的主機名;默認為true; 進行反解的,可以設置為false 8) acceptCount:設置等待隊列的最大長度;通常在tomcat所有處理線程均處于繁忙狀態(tài)時,新發(fā)來的請求將被放置于等待隊列中; 下面是一個定義了多個屬性的連接器 maxThreads=”150″ minSpareThreads=”25″ maxSpareThreads=”75″
Engine是Servlet處理器的一個實例,即servlet引擎,默認為定義在server.xml中的Catalina。Engine需要defaultHost屬性來為其定義一個接收所有發(fā)往非明確定義虛擬主機的請求的host組件。如前面示例中定義的: <Engine name=”Catalina” defaultHost=”localhost”> 常用的屬性定義: defaultHost:Tomcat支持基于FQDN的虛擬主機,這些虛擬主機可以通過在Engine容器中定義多個不同的Host組件來實現(xiàn);但如果此引擎的連接器收到一個發(fā)往非非明確定義虛擬主機的請求時則需要將此請求發(fā)往一個默認的虛擬主機進行處理,因此,在Engine中定義的多個虛擬主機的主機名稱中至少要有一個跟defaultHost定義的主機名稱同名; name:Engine組件的名稱,用于日志和錯誤信息記錄時區(qū)別不同的引擎; Engine容器中可以包含Realm、Host、Listener和Valve子容器。
位于Engine容器中用于接收請求并進行相應處理的主機或虛擬主機,如前面示例中的定義: <Host name=”localhost” appBase=”webapps” 常用屬性說明: 1) appBase:此Host的webapps目錄,即存放非歸檔的web應用程序的目錄或歸檔后的WAR文件的目錄路徑;可以使用基于$CATALINA_HOME的相對路徑; 2) autoDeploy:在Tomcat處于運行狀態(tài)時放置于appBase目錄中的應用程序文件是否自動進行deploy;默認為true; 3) unpackWars:在啟用此webapps時是否對WAR格式的歸檔文件先進行展開;默認為true; 虛擬主機定義示例: <Engine name=”Catalina” defaultHost=”localhost”> <Host name=”mail.magedu.com” appBase=”/web/mail”> 主機別名定義: 如果一個主機有兩個或兩個以上的主機名,額外的名稱均可以以別名的形式進行定義,如下:
Context在某些意義上類似于apache中的路徑別名,一個Context定義用于標識tomcat實例中的一個Web應用程序;如下面的定義: <!– Tomcat Root Context –> <!– buzzin webapp –> <!– chat server –> <!– darian web –> 在Tomcat6中,每一個context定義也可以使用一個單獨的XML文件進行,其文件的目錄為$CATALINA_HOME/conf//??梢杂糜贑ontext中的XML元素有Loader,Manager,Realm,Resources和WatchedResource。 常用的屬性定義有: 1) docBase:相應的Web應用程序的存放位置;也可以使用相對路徑,起始路徑為此Context所屬Host中appBase定義的路徑;切記,docBase的路徑名不能與相應的Host中appBase中定義的路徑名有包含關系,比如,如果appBase為deploy,而docBase絕不能為deploy-bbs類的名字; 2) path:相對于Web服務器根路徑而言的URI;如果為空“”,則表示為此webapp的根路徑;如果context定義在一個單獨的xml文件中,此屬性不需要定義,有可能是別名; 3) reloadable:是否允許重新加載此context相關的Web應用程序的類;默認為false;
一個Realm表示一個安全上下文,它是一個授權訪問某個給定Context的用戶列表和某用戶所允許切換的角色相關定義的列表。因此,Realm就像是一個用戶和組相關的數(shù)據(jù)庫。定義Realm時惟一必須要提供的屬性是classname,它是Realm的多個不同實現(xiàn),用于表示此Realm認證的用戶及角色等認證信息的存放位置。 JAASRealm:基于Java Authintication and Authorization Service實現(xiàn)用戶認證; JDBCRealm:通過JDBC訪問某關系型數(shù)據(jù)庫表實現(xiàn)用戶認證; JNDIRealm:基于JNDI使用目錄服務實現(xiàn)認證信息的獲取; MemoryRealm:查找tomcat-user.xml文件實現(xiàn)用戶信息的獲??; UserDatabaseRealm:基于UserDatabase文件(通常是tomcat-user.xml)實現(xiàn)用戶認證,它實現(xiàn)是一個完全可更新和持久有效的MemoryRealm,因此能夠跟標準的MemoryRealm兼容;它通過JNDI實現(xiàn); 下面是一個常見的使用UserDatabase的配置: <Realm className=”org.apache.catalina.realm.UserDatabaseRealm” 下面是一個使用JDBC方式獲取用戶認證信息的配置: <Realm className=”org.apache.catalina.realm.JDBCRealm” debug=”99″
Valve類似于過濾器,它可以工作于Engine和Host/Context之間、Host和Context之間以及Context和Web應用程序的某資源之間。一個容器內可以建立多個Valve,而且Valve定義的次序也決定了它們生效的次序。Tomcat6中實現(xiàn)了多種不同的Valve: AccessLogValve:訪問日志Valve ExtendedAccessValve:擴展功能的訪問日志Valve JDBCAccessLogValve:通過JDBC將訪問日志信息發(fā)送到數(shù)據(jù)庫中; RequestDumperValve:請求轉儲Valve; RemoteAddrValve:基于遠程地址的訪問控制; RemoteHostValve:基于遠程主機名稱的訪問控制; SemaphoreValve:用于控制Tomcat主機上任何容器上的并發(fā)訪問數(shù)量; JvmRouteBinderValve:在配置多個Tomcat為以Apache通過mod_proxy或mod_jk作為前端的集群架構中,當期望停止某節(jié)點時,可以通過此Valve將用記請求定向至備用節(jié)點;使用此Valve,必須使JvmRouteSessionIDBinderListener; ReplicationValve:專用于Tomcat集群架構中,可以在某個請求的session信息發(fā)生更改時觸發(fā)session數(shù)據(jù)在各節(jié)點間進行復制; SingleSignOn:將兩個或多個需要對用戶進行認證webapp在認證用戶時連接在一起,即一次認證即可訪問所有連接在一起的webapp; ClusterSingleSingOn:對SingleSignOn的擴展,專用于Tomcat集群當中,需要結合ClusterSingleSignOnListener進行工作; RemoteHostValve和RemoteAddrValve可以分別用來實現(xiàn)基于主機名稱和基于IP地址的訪問控制,控制本身可以通過allow或deny來進行定義,這有點類似于Apache的訪問控制功能;如下面的Valve則實現(xiàn)了僅允許本機訪問/probe: <Context path=”/probe” docBase=”probe”> 其中相關屬性定義有: 1) className:相關的java實現(xiàn)的類名,相應于分別應該為org.apache.catalina.valves.RemoteHostValve或org.apache.catalina.valves.RemoteAddrValve; 2) allow:以逗號分開的允許訪問的IP地址列表,支持正則表達式,因此,點號“.”用于IP地址時需要轉義;僅定義allow項時,非明確allow的地址均被deny; 3) deny: 以逗號分開的禁止訪問的IP地址列表,支持正則表達式;使用方式同allow;
應用于整個服務器的JNDI映射,此可以避免每個Web應用程序都需要在各自的web.xml創(chuàng)建,這在web應用程序以WAR的形式存在時尤為有用。它通??梢园齻€子元素:
WatchedResource可以用于Context中監(jiān)視指定的webapp程序文件的改變,并且能夠在監(jiān)視到文件內容發(fā)生改變時重新裝載此文件。
Listener用于創(chuàng)建和配置LifecycleListener對象,而LifecycleListener通常被開發(fā)人員用來創(chuàng)建和刪除容器。
Java的動態(tài)裝載功能是其語言功能強大表現(xiàn)之一,Servlet容器使用此功能在運行時動態(tài)裝載servlet和它們所依賴的類。Loader可以用于Context中控制java類的加載。
Manger對象用于實現(xiàn)HTTP會話管理的功能,Tomcat6中有5種Manger的實現(xiàn): 1) StandardManager Tomcat6的默認會話管理器,用于非集群環(huán)境中對單個處于運行狀態(tài)的Tomcat實例會話進行管理。當Tomcat關閉時,這些會話相關的數(shù)據(jù)會被寫入磁盤上的一個名叫SESSION.ser的文件,并在Tomcat下次啟動時讀取此文件。 2) PersistentManager 當一個會話長時間處于空閑狀態(tài)時會被寫入到swap會話對象,這對于內存資源比較吃緊的應用環(huán)境來說比較有用。 3)DeltaManager 用于Tomcat集群的會話管理器,它通過將改變了會話數(shù)據(jù)同步給集群中的其它節(jié)點實現(xiàn)會話復制。這種實現(xiàn)會將所有會話的改變同步給集群中的每一個節(jié)點,也是在集群環(huán)境中用得最多的一種實現(xiàn)方式。 4)BackupManager 用于Tomcat集群的會話管理器,與DeltaManager不同的是,某節(jié)點會話的改變只會同步給集群中的另一個而非所有節(jié)點。 5)SimpleTcpReplicationManager Tomcat4時用到的版本,過于老舊了。
PersistentManager必須包含一個Store元素以指定將會話數(shù)據(jù)存儲至何處。這通常有兩種實現(xiàn)方式:FileStore和JDBCStore。
經(jīng)常用于實現(xiàn)在Context中指定需要裝載的但不在Tomcat本地磁盤上的應用資源,如Java類,HTML頁面,JSP文件等。
專用于配置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元素。 16.1、Channel 用于Cluster中給集群中同一組中的節(jié)點定義通信“信道”。Channel中需要至少定義Membership、Receiver和Sender三個元素,此外還有一個可選元素Interceptor。 16.2、Membership 用于Channel中配置同一通信信道上節(jié)點集群組中的成員情況,即監(jiān)控加入當前集群組中的節(jié)點并在各節(jié)點間傳遞心跳信息,而且可以在接收不到某成員的心跳信息時將其從集群節(jié)點中移除。Tomcat6中Membership的實現(xiàn)是org.apache.catalina.tribes.membership.McastService。 16.3、Sender 用于Channel中配置“復制信息”的發(fā)送器,實現(xiàn)發(fā)送需要同步給其它節(jié)點的數(shù)據(jù)至集群中的其它節(jié)點。發(fā)送器不需要屬性的定義,但可以在其內部定義一個Transport元素。 16.4 Transport 用于Sender內部,配置數(shù)據(jù)如何發(fā)送至集群中的其它節(jié)點。Tomcat6有兩種Transport的實現(xiàn): 1) PooledMultiSender 基于Java阻塞式IO,可以將一次將多個信息并發(fā)發(fā)送至其它節(jié)點,但一次只能傳送給一個節(jié)點。 2)PooledParallelSener 基于Java非阻塞式IO,即NIO,可以一次發(fā)送多個信息至一個或多個節(jié)點。 16.5 Receiver 用于Channel定義某節(jié)點如何從其它節(jié)點的Sender接收復制數(shù)據(jù),Tomcat6中實現(xiàn)的接收方式有兩種BioReceiver和NioReceiver。
web.xml基于Java Servlet規(guī)范,可被用于每一個Java servlet容器,通常有兩個存放位置,$CATALINA_BASE/conf和每個Web應用程序(通常是WEB-INF/web.xml)。Tomcat在deploy一個應用程序時(包括重啟或重新載入),它首先讀取conf/web.xml,而后讀取WEB-INF/web.xml。
<server> 頂級組件:位于整個配置的頂層;<server> 容器類:可以包含其它組件的組件;<service> 連接器組件:連接用戶請求至tomcat;<connector /> 被嵌套類的組件:位于一個容器當中,不能包含其它組件; 容器類: engine: 核心容器,catalina引擎,負責通過connector接收用戶請求 host: 類似于httpd中的虛擬主機;支持基于FQDN的虛擬主機 context: 最內層的容器類組件,一個context代表一個web應用程序;配置context的主要目的,指定對應的webapp的根目錄;還能為webapp指定額外的屬性,如部署方式等; 服務:service, 將連接器關聯(lián)至engine;因此一個service內部可以有多個connector,但只能有一個engine; 頂級組件:server,表示一個運行于JVM中的tomcat實例; 嵌套類組件: valve: 攔截請求并在將其轉至對應的webapp之前進行某種處理操作;可以用于任何容器中; access log valve: 響應前先記錄日志 remote address filter value: 基于IP做訪問控制 logger: 日志記錄器,用于記錄組件 內部的狀態(tài)信息; 可用于除context之外的任何容器中 realm: 可以用于任何容器類的組件中,關聯(lián)一個用戶認證庫,實現(xiàn)認證和授權; UserDatabaseRealm: 使用JNDI自定義的用戶認證庫; MemoryRealm: tomcat-users.xml中 JDBCRealm: 基于JDBC連接至數(shù)據(jù)庫中查找用戶;
webapp有特定的組織格式,是一種層次型目錄結構;通常包含了servlet代碼文件、jsp頁面文件、類文件、部署描述符文件等等,一般會打包成歸檔格式; /: web應用程序的根目錄 ,ROOT為根目錄 /WEB-INF: 包含當前webapp的deploy描述符,如所有的servlets和JSP等動態(tài)文件的詳細信息,會話超時時間和數(shù)據(jù)源等;因此,其也通常用于定義當前webapp特有的資源,通常web.xml和context.xml均放置于此目錄; /WEB-INF/classes: 包含所有服務器端類及當前應用程序相關的其它第三方類等;; /WEB-INF/lib: 包含JSP所用到的JAR文件,此webapp自有能夠被打包為jar格式的類;
Tomcat的HTTP連接器有三種: 1) 基于java的HTTP/1.1連接器,這也是Tomcat6默認使用的連接器,即Coyote;它是Tomcat作為standalone模式工作時所用到的連接器,可直接響應來自用戶瀏覽器的關于JSP、servlet和HTML的請求;此連接器是一個Java類,定義在server.xml當中,默認使用8080端口; 2) Java開發(fā)的高性能NIO HTTP/1.1連接器,它支持非阻塞式IO和Comnet,在基于庫向tomcat發(fā)起請求時,此連接器表現(xiàn)不俗;但其實現(xiàn)不太成熟,有嚴重bug存在; 3) C/C++開發(fā)的native APR HTTP/1.1連接器;在負載較大的場景中,此連接器可以提供非常好的性能;APR即Apache Portable Runtime,它是一個能讓開發(fā)者采用與平臺無關的風格的方式來開發(fā)C/C++代碼本地庫,它能夠很好的跨Windows, Linux和Unix平臺工作。此連接器從三個主要方面優(yōu)化了系統(tǒng)性能并提升了系統(tǒng)的伸縮能力: (1)使用sendfile()內核模式調用發(fā)送大的靜態(tài)文件; (2) 僅使用一個native code保持大量的連接; (3) 使用能夠加速SSL請求處理的OpenSSL本地代碼; 啟用APR連接器的條件: 1) 將連接器的protocol屬性設定為org.apache.coyote.http11.Http11AprProtocol,即 2) APR的庫文件已經(jīng)在系統(tǒng)庫文件的搜索路徑內,必須額外編譯安裝apr; 基于連接器提高Tomcat性能的方法: 1) 設置tcpNoDelay屬性值為“true”; 2) 通過maxKeepAliveRequest屬性調整允許keep-alive功能的請求的最大數(shù)目,值為1時表示禁用; 3) 調整socketBuffer屬性的值以改變套接字緩沖的大??; 4) 將enableLookups設置為false以禁用DNS反解; 5) Tomcat是一個多線程的Servlet容器,使用線程池能對服務器性能帶去很大影響;這主要通過maxThreads、maxSpareThreads和minSpareThreads來定義; 6) 通過JAVA_OPTS,如-Xms和-Xmx設定JVM相關的參數(shù)以定義其使用內存的能力; AJP(Apache JServ Protocol)連接器 :AJP是面向數(shù)據(jù)包的基于TCP/IP的協(xié)議,它在Apache和Tomcat的實例之間提供了一個專用的通信信道。目前常用AJP協(xié)議的版本是1.3,它主要有以下特征: 1) 在快速網(wǎng)絡有著較好的性能表現(xiàn),支持數(shù)據(jù)壓縮傳輸; 2) 支持SSL,加密及客戶端證書; 3) 支持Tomcat實例集群; 4) 支持在apache和tomcat之間的連接的重用; 四,配置Tomcat定義虛擬主機,將虛擬主機定義在/www/webapps 下,在配置文件中的 Engine 組件中添加: <Host name=”” appBase=”/www/webapps” 注釋掉上面的虛擬主機,修改server.xml,作如下修改,在/webapps/目錄下創(chuàng)建test目錄,并添加測試頁面index.jsp: <Host name=”buy.” appBase=”webapps” <Valve className=”org.apache.catalina.valves.AccessLogValve” directory=”logs” |
|