Tomcat配置詳解

<Server>元素
它代表整個容器,是Tomcat實例的頂層元素.由org.apache.catalina.Server接口來定義.它包含一個<Service>元素.並且它不能做爲任何元素的子元素.
<Server port="8005" shutdown="SHUTDOWN" debug="0">
1>className指定實現org.apache.catalina.Server接口的類.默認值爲org.apache.catalina.core.StandardServer
2>port指定Tomcat監聽shutdown命令端口.終止服務器運行時,必須在Tomcat服務器所在的機器上發出shutdown命令.該屬性是必須的.
3>shutdown指定終止Tomcat服務器運行時,發給Tomcat服務器的shutdown監聽端口的字符串.該屬性必須設置
<Service>元素
該元素由org.apache.catalina.Service接口定義,它包含一個<Engine>元素,以及一個或多個<Connector>,這些Connector元素共享用同一個Engine元素

<Service name="Catalina">
<Service name="Apache">
第一個<Service>處理所有直接由Tomcat服務器接收的web客戶請求.
第二個<Service>處理所有由Apahce服務器轉發過來的Web客戶請求
1>className 指定實現org.apahce.catalina.Service接口的類.默認爲org.apahce.catalina.core.StandardService
2>name定義Service的名字
<Engine>元素
每個Service元素只能有一個Engine元素.元素處理在同一個<Service>中所有<Connector>元素接收到的客戶請求.由org.apahce.catalina.Engine接口定義.
<Engine name="Catalina" defaultHost="localhost" debug="0">
1>className指定實現Engine接口的類,默認值爲StandardEngine
2>defaultHost指定處理客戶的默認主機名,在<Engine>中的<Host>子元素中必須定義這一主機
3>name定義Engine的名字,在<Engine>可以包含如下元素<Logger>, <Realm>, <Value>, <Host>
<Host>元素
它由Host接口定義.一個Engine元素可以包含多個<Host>元素.每個<Host>的元素定義了一個虛擬主機.它包含了一個或多個Web應用.
<Host name="localhost" debug="0" appBase="webapps" unpackWARs="true" autoDeploy="true">
1>className指定實現Host接口的類.默認值爲StandardHost
2>appBase指定虛擬主機的目錄,可以指定絕對目錄,也可以指定相對於<CATALINA_HOME>的相對目錄.如果沒有此項,默認爲<CATALINA_HOME>/webapps
3>autoDeploy如果此項設爲true,表示Tomcat服務處於運行狀態時,能夠監測appBase下的文件,如果有新有web應用加入進來,會自運發佈這個WEB應用
4>unpackWARs如果此項設置爲true,表示把WEB應用的WAR文件先展開爲開放目錄結構後再運行.如果設爲false將直接運行爲WAR文件
5>alias指定主機別名,可以指定多個別名
6>deployOnStartup如果此項設爲true,表示Tomcat服務器啓動時會自動發佈appBase目錄下所有的Web應用.如果Web應用中的server.xml沒有相應的<Context>元素,將採用Tomcat默認的Context
7>name定義虛擬主機的名字,在<Host>元素中可以包含如下子元素<Logger>, <Realm>, <Value>, <Context>
<Context>元素
它由Context接口定義.是使用最頻繁的元素.每個<Context元素代表了運行在虛擬主機上的單個Web應用.一個<Host>可以包含多個<Context>元素.每個web應用有唯一
的一個相對應的Context代表web應用自身.servlet容器爲第一個web應用創建一個
ServletContext對象.
<Context path="/sample" docBase="sample" debug="0" reloadbale="true">
1>className指定實現Context的類,默認爲StandardContext類
2>path指定訪問Web應用的URL入口,注意/myweb,而不是myweb了事
3>reloadable如果這個屬性設爲true, Tomcat服務器在運行狀態下會監視在WEB-INF/classes和Web-INF/lib目錄CLASS文件的改運.如果監視到有class文件被更新,服務器自重新加載Web應用
3>cookies指定是否通過Cookies來支持Session,默認值爲true
4>useNaming指定是否支持JNDI,默認值爲了true,在<Context>元素中可以包含如下元素
<Logger>, <Realm>, <Resource>, <ResourceParams>
<Connector>元素由Connector接口定義.<Connector>元素代表與客戶程序實際交互的給件,它負責接收客戶請求,以及向客戶返回響應結果.
<Connector port="8080" maxThread="50" minSpareThreads="25" maxSpareThread="75" enableLookups="false" redirectPort="8443" acceptCount="100" debug="0" connectionTimeout="20000" disableUploadTimeout="true" />
<Connection port="8009" enableLookups="false" redirectPort="8443" debug="0" protocol="AJP/1.3" />
第一個Connector元素定義了一個HTTP Connector,它通過8080端口接收HTTP請求;第二個Connector元素定義了一個JD Connector,它通過8009端口接收由其它服務器轉發過來的請求.
Connector元素共用屬性
1>className指定實現Connector接口的類
2>enableLookups如果設爲true,表示支持域名解析,可以把IP地址解析爲主機名.WEB應用中調用request.getRemoteHost方法返回客戶機主機名.默認值爲true
3>redirectPort指定轉發端口.如果當前端口只支持non-SSL請求,在需要安全通信的場命,將把客戶請求轉發至SSL的redirectPort端口
HttpConnector元素的屬性
1>className實現Connector的類
2>port設定Tcp/IP端口,默認值爲8080,如果把8080改成80,則只要輸入http://localhost即可
因爲TCP/IP的默認端口是80
3>address如果服務器有二個以上ip地址,此屬性可以設定端口監聽的ip地址.默認情況下,端口會監聽服務器上所有的ip地址
4>bufferSize設定由端口創建的輸入流的緩存大小.默認值爲2048byte
5>protocol設定Http協議,默認值爲HTTP/1.1
6>maxThreads設定在監聽端口的線程的最大數目,這個值也決定了服務器可以同時響應客戶請求的最大數目.默認值爲200
7>acceptCount設定在監聽端口隊列的最大客戶請求數量,默認值爲10.如果隊列已滿,客戶必須等待.
8>connectionTimeout定義建立客戶連接超時的時間.如果爲-1,表示不限制建立客戶連接的時間
JkConnector的屬性
1>className實現Connector的類
2>port設定AJP端口號
3>protocol必須設定爲AJP/1.3
Tomcat管理
1:配置
在進行具體的管理之前,我們先給tomcat添加一個用戶,使這個用戶有權限來進行管理。
打開conf目錄下的tomcat-users.xml文件,在相應的位置添加下面一行:
<user name="zf" password="zf" roles="standard,manager"/>

注意:這一行的最後部分一定是/>,tomcat的文檔掉了/符號,如果沒有/符號的話,tomcat重起時將無法訪問應用程序。通過logs/catalina.out文件你可以看到這個錯誤的詳細信息。
然後重起tomcat,在瀏覽器中輸入http://localhost:8080/manager/,會彈出對話框,輸入上面的用戶名和密碼即可。
2:應用程序列表
在瀏覽器中輸入http://localhost:8080/manager/list,瀏覽器將會顯示如下的信息:
OK - Listed applications for virtual host localhost/ex:running:1/examples:running:1/webdav:running:0/tomcat-docs:running:0/manager:running:0/:running:0

面的信息分別爲應用程序的路徑,當前狀態(running 或者stopped),與這個程序相連的session數。
3:重新裝載應用程序
在瀏覽器中輸入 http://localhost:8080/manager/reload?path=/examples,瀏覽器顯示如下:
OK - Reloaded application at context path /examples

表示example應用程序裝載成功,如果我們將server.xml的Context元素的reloadable屬性設爲true(見上面表格),則沒必要利用這種方式重新裝載應用程序,因爲tomcat會自動裝載。
4:顯示session信息
在瀏覽器中輸入http://localhost:8080/manager/sessions?path=/examples,瀏覽器顯示如下:
OK - Session information for application at context path /examples Default maximum session inactive interval 30 minutes

5:啓動和關閉應用程序
在瀏覽器中輸入http://localhost:8080/manager/start?path=/examples和http://localhost:8080/manager/stop?path=/examples分別啓動和關閉examples應用程序。
6:部署及撤銷部署
WAR有兩種組織方式,一種是按一定的目錄結構組織文件,一種是一個後綴爲WAR的壓縮包,因此它的部署方式也有兩種:
(1):在瀏覽器中輸入:http://localhost:8080/manager/install?path=/examples&war=file:/c:/examples
就會將按目錄結構組織的WAR部署
(2):如果輸入:http://localhost:8080/manager/install?path=/examples&war=jar:file:/c:/examples.war!/
就會將按壓縮包組織的WAR部署,注意此url後半部分一定要有!/號。
部署後就可以用 http://localhost:8080/examples訪問了。
在瀏覽器中輸入:http://localhost:8080/manager/remove?path=/examples
就會撤銷剛纔部署的應用程序。
例子
<?xml version="1.0" encoding="UTF-8"?>
<Server port="8005" shutdown="SHUTDOWN">
<Listener className="org.apache.catalina.core.AprLifecycleListener"/>
<Listener className="org.apache.catalina.mbeans.ServerLifecycleListener"/>
<Listener className="org.apache.catalina.mbeans.GlobalResourcesLifecycleListener"/>
<Listener className="org.apache.catalina.storeconfig.StoreConfigLifecycleListener"/>
<GlobalNamingResources>
<Environment name="simpleValue" type="java.lang.Integer" value="30"/>
<Resource auth="Container" description="User database that can be updated and saved" factory="org.apache.catalina.users.MemoryUserDatabaseFactory" name="UserDatabase" pathname="conf/tomcat-users.xml" type="org.apache.catalina.UserDatabase"/>
</GlobalNamingResources>
<Service name="Catalina">
<Connector acceptCount="100" connectionTimeout="20000" disableUploadTimeout="true" enableLookups="false" maxHttpHeaderSize="8192" maxSpareThreads="75" maxThreads="150" minSpareThreads="25" port="80" redirectPort="8443"/>
<!-- 1、port="80"爲設置客戶端訪問tomcat時的端口號,默認是8080,改成80端口後可以在訪問tomcat時不需要輸入端口號就可以訪問;
2、minProcessors: 服務器啓動時創建的處理請求的線程數;
3、maxProcessors: 最大可以創建的處理請求的線程數;
4、enableLookups :如果爲true,則可以通過調用request.getRemoteHost()進行DNS查詢來得到遠程客戶端的實際主機名,若爲false則不進行DNS查詢,而是返回其ip地址;
5、redirectPort:指定服務器正在處理http請求時收到了一個SSL傳輸請求後重定向的端口號;
6、acceptCount:指定當所有可以使用的處理請求的線程數都被使用時,可以放到處理隊列中的請求數,超過這個數的請求將不予處理;
7、connectionTimeout:指定超時的時間數(以毫秒爲單位);
-->
<Connector enableLookups="false" port="8009" protocol="AJP/1.3" redirectPort="8443"/>
<Engine defaultHost="www.85salary.com" name="Catalina">
<!-- 1、defaultHost:指定缺省的處理請求的主機名,它至少與其中的一個host元素的name屬性值是一樣的在下; -->
<Realm className="org.apache.catalina.realm.UserDatabaseRealm" resourceName="UserDatabase"/>
<Host appBase="/usr/local/tomcat/webapps" autoDeploy="true" name="www.85salary.com" unpackWARs="true" xmlNamespaceAware="false" xmlValidation="false">
<!-- Host:標籤的作用是建立虛擬主機
1、appBase:爲項目所在目錄即www.85Salary.com訪問時的根目錄""中的內容有2種寫法1)相對路徑,相對的是tomcat安裝目錄下(apache-tomcat-5.5.25)如:appBase="webapps";2)絕對路徑,是針對實際的目錄,如:appBase="/usr/local/apache-tomcat-5.5.25/webapps",這個可以配置項目工程在tomcat安裝目錄之外的情況;
2、name:(指定主機名稱)需要寫入要配置的域名,只能輸入域名;
unpackWARs:如果爲true,則tomcat會自動將WAR文件解壓,否則不解壓,直接從WAR文件中運行應用程序; -->
<Context docBase="85Salary" path="" reloadable="true" />
<!-- Context:的作用是建立虛擬目錄
1、docBase:配置虛擬目錄的位置,85Salary是在host裏的appBase="/usr/local/apache-tomcat-5.5.25/webapps"之下;
2、path:表示此web應用程序的url的前綴,這樣請求的url爲http://www.85salary.com/path/index.jsp,如果爲""則以http://www.85salary.com/index.jsp的路徑訪問,目前我們就是利用這一點實現域名直接訪問首頁的;
3、reloadable:這個屬性非常重要,如果爲true,則tomcat會自動檢測應用程序的/WEB-INF/lib 和/WEB-INF/classes目錄的變化,自動裝載新的應用程序,我們可以在不重起tomcat的情況下改變應用程序 -->
</Host>
<Host appBase="webapps" autoDeploy="true" name="localhost" unpackWARs="true" xmlNamespaceAware="false" xmlValidation="false"></Host>
</Engine>
</Service>
</Server>
發佈了38 篇原創文章 · 獲贊 17 · 訪問量 17萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章