server.xml配置簡介
下面是這個文件中的基本配置信息,更具體的配置信息見tomcat的文檔
server:
port 指定一個端口,這個端口負責監聽關閉tomcat的請求
shutdown 指定向端口發送的命令字符串
service:
name 指定service的名字
Connector (表示客戶端和service之間的連接):
port 指定服務器端要創建的端口號,並在這個斷口監聽來自客戶端的請求
minProcessors 服務器啟動時創建的處理請求的線程數
maxProcessors 最大可以創建的處理請求的線程數
enableLookups 如果為true,則可以通過調用request.getRemoteHost()進行DNS查詢來得到遠程客戶端的實際主機名,若為false則不進行DNS查詢,而是返回其ip地址
redirectPort 指定服務器正在處理http請求時收到了一個SSL傳輸請求后重定向的端口號
acceptCount 指定當所有可以使用的處理請求的線程數都被使用時,可以放到處理隊列中的請求數,超過這個數的請求將不予處理
connectionTimeout 指定超時的時間數(以毫秒為單位)
Engine (表示指定service中的請求處理機,接收和處理來自Connector的請求):
defaultHost 指定缺省的處理請求的主機名,它至少與其中的一個host元素的name屬性值是一樣的
Context (表示一個web應用程序,通常為WAR文件,關於WAR的具體信息見servlet規范):
docBase 應用程序的路徑或者是WAR文件存放的路徑
path 表示此web應用程序的url的前綴,這樣請求的url為http://localhost:8080/path/****
reloadable 這個屬性非常重要,如果為true,則tomcat會自動檢測應用程序的/WEB-INF/lib 和/WEB-INF/classes目錄的變化,自動裝載新的應用程序,我們可以在不重起tomcat的情況下改變應用程序
host (表示一個虛擬主機):
name 指定主機名
appBase 應用程序基本目錄,即存放應用程序的目錄
unpackWARs 如果為true,則tomcat會自動將WAR文件解壓,否則不解壓,直接從WAR文件中運行應用程序
Logger (表示日志,調試和錯誤信息):
className 指定logger使用的類名,此類必須實現org.apache.catalina.Logger 接口
prefix 指定log文件的前綴
suffix 指定log文件的后綴
timestamp 如果為true,則log文件名中要加入時間,如下例:localhost_log.2001-10-04.txt
Realm (表示存放用戶名,密碼及role的數據庫):
className 指定Realm使用的類名,此類必須實現org.apache.catalina.Realm接口
Valve (功能與Logger差不多,其prefix和suffix屬性解釋和Logger 中的一樣):
className 指定Valve使用的類名,如用org.apache.catalina.valves.AccessLogValve類可以記錄應用程序的訪問信息
directory 指定log文件存放的位置
pattern 有兩個值,common方式記錄遠程主機名或ip地址,用戶名,日期,第一行請求的字符串,HTTP響應代碼,發送的字節數。combined方式比common方式記錄的值更多
注意:
默認的server.xml中,Realm元素只設置了一個className屬性,但此文件中也包含幾個通過JDBC連接到數據庫進行驗證的示例(被注釋掉了),通過Realm元素我們可以實現容器安全管理(Container Managed Security)。
還有一些元素,如Parameter,loader,你可以通過tomcat的文檔獲取這些元素的信息。
----------------------------------------------------------------------
Tomcat中Context的配置
當我們開發完一個Web應用后,我們需要將該應用發布到Web Server中,以便其他用戶可以訪問。在JAVA的WEB開發領域,我們通常使用TOMCAT作為我們的WEB服務器進行測試或正式部署。
一般我們將WEB應用打包成WAR格式,然后拷貝到TOMCAT的WEBAPP目錄下進行發布,在正常情況下,TOMCAT將自動解壓WAR文件並生成對應的目錄,而且會在內存中動態創建該WEB應用對應的CONTEXT路徑。比如我們的WAR文件是Sample.war,那么解壓后的目錄就是Sample目錄,在內存中動態創建的Context路徑就是/Sample。在開發階段這樣的默認行為是可以接受的,但是在正式部署的情況下,我們通常需要修改應用的Context路徑以適應我們的需要。
如果我們想讓用戶僅僅輸入域名來訪問我們的Sample應用,我們就需要修改Tomcat的Context設置。具體如何設置Context路徑的方式有兩種,一種是修改{TOMCAT_HOME}/conf/server.xml文件,另一種是建立一個Context片段文件放在webapps目錄下。我們這里介紹第一種方式。
使用任何文本編輯器打開server.xml文件,在<Host>節點下增加<Context>節點,並設置path,docBase,debug和reloadable屬性,如下:
下面是這個文件中的基本配置信息,更具體的配置信息見tomcat的文檔
server:
port 指定一個端口,這個端口負責監聽關閉tomcat的請求
shutdown 指定向端口發送的命令字符串
service:
name 指定service的名字
Connector (表示客戶端和service之間的連接):
port 指定服務器端要創建的端口號,並在這個斷口監聽來自客戶端的請求
minProcessors 服務器啟動時創建的處理請求的線程數
maxProcessors 最大可以創建的處理請求的線程數
enableLookups 如果為true,則可以通過調用request.getRemoteHost()進行DNS查詢來得到遠程客戶端的實際主機名,若為false則不進行DNS查詢,而是返回其ip地址
redirectPort 指定服務器正在處理http請求時收到了一個SSL傳輸請求后重定向的端口號
acceptCount 指定當所有可以使用的處理請求的線程數都被使用時,可以放到處理隊列中的請求數,超過這個數的請求將不予處理
connectionTimeout 指定超時的時間數(以毫秒為單位)
Engine (表示指定service中的請求處理機,接收和處理來自Connector的請求):
defaultHost 指定缺省的處理請求的主機名,它至少與其中的一個host元素的name屬性值是一樣的
Context (表示一個web應用程序,通常為WAR文件,關於WAR的具體信息見servlet規范):
docBase 應用程序的路徑或者是WAR文件存放的路徑
path 表示此web應用程序的url的前綴,這樣請求的url為http://localhost:8080/path/****
reloadable 這個屬性非常重要,如果為true,則tomcat會自動檢測應用程序的/WEB-INF/lib 和/WEB-INF/classes目錄的變化,自動裝載新的應用程序,我們可以在不重起tomcat的情況下改變應用程序
host (表示一個虛擬主機):
name 指定主機名
appBase 應用程序基本目錄,即存放應用程序的目錄
unpackWARs 如果為true,則tomcat會自動將WAR文件解壓,否則不解壓,直接從WAR文件中運行應用程序
Logger (表示日志,調試和錯誤信息):
className 指定logger使用的類名,此類必須實現org.apache.catalina.Logger 接口
prefix 指定log文件的前綴
suffix 指定log文件的后綴
timestamp 如果為true,則log文件名中要加入時間,如下例:localhost_log.2001-10-04.txt
Realm (表示存放用戶名,密碼及role的數據庫):
className 指定Realm使用的類名,此類必須實現org.apache.catalina.Realm接口
Valve (功能與Logger差不多,其prefix和suffix屬性解釋和Logger 中的一樣):
className 指定Valve使用的類名,如用org.apache.catalina.valves.AccessLogValve類可以記錄應用程序的訪問信息
directory 指定log文件存放的位置
pattern 有兩個值,common方式記錄遠程主機名或ip地址,用戶名,日期,第一行請求的字符串,HTTP響應代碼,發送的字節數。combined方式比common方式記錄的值更多
注意:
默認的server.xml中,Realm元素只設置了一個className屬性,但此文件中也包含幾個通過JDBC連接到數據庫進行驗證的示例(被注釋掉了),通過Realm元素我們可以實現容器安全管理(Container Managed Security)。
還有一些元素,如Parameter,loader,你可以通過tomcat的文檔獲取這些元素的信息。
----------------------------------------------------------------------
Tomcat中Context的配置
當我們開發完一個Web應用后,我們需要將該應用發布到Web Server中,以便其他用戶可以訪問。在JAVA的WEB開發領域,我們通常使用TOMCAT作為我們的WEB服務器進行測試或正式部署。
一般我們將WEB應用打包成WAR格式,然后拷貝到TOMCAT的WEBAPP目錄下進行發布,在正常情況下,TOMCAT將自動解壓WAR文件並生成對應的目錄,而且會在內存中動態創建該WEB應用對應的CONTEXT路徑。比如我們的WAR文件是Sample.war,那么解壓后的目錄就是Sample目錄,在內存中動態創建的Context路徑就是/Sample。在開發階段這樣的默認行為是可以接受的,但是在正式部署的情況下,我們通常需要修改應用的Context路徑以適應我們的需要。
如果我們想讓用戶僅僅輸入域名來訪問我們的Sample應用,我們就需要修改Tomcat的Context設置。具體如何設置Context路徑的方式有兩種,一種是修改{TOMCAT_HOME}/conf/server.xml文件,另一種是建立一個Context片段文件放在webapps目錄下。我們這里介紹第一種方式。
使用任何文本編輯器打開server.xml文件,在<Host>節點下增加<Context>節點,並設置path,docBase,debug和reloadable屬性,如下:
XmlCode :
- <?xml version="1.0" encoding="UTF-8"?>
- <Server>
- <Listener className="org.apache.catalina.mbeans.GlobalResourcesLifecycleListener"/>
- <Listener className="org.apache.catalina.storeconfig.StoreConfigLifecycleListener"/>
- <Listener className="org.apache.catalina.mbeans.ServerLifecycleListener"/>
- <GlobalNamingResources>
- <Environment
- name="simpleValue"
- type="java.lang.Integer"
- value="30"/>
- <Resource
- auth="Container"
- description="User database that can be updated and saved"
- name="UserDatabase"
- type="org.apache.catalina.UserDatabase"
- pathname="conf/tomcat-users.xml"
- factory="org.apache.catalina.users.MemoryUserDatabaseFactory"/>
- </GlobalNamingResources>
- <Service
- name="Catalina">
- <Connector
- port="8080"
- redirectPort="8443"
- minSpareThreads="25"
- connectionTimeout="20000"
- maxSpareThreads="75"
- maxThreads="150"
- maxHttpHeaderSize="8192">
- </Connector>
- <Connector
- port="8009"
- redirectPort="8443"
- protocol="AJP/1.3">
- </Connector>
- <Engine
- defaultHost="localhost"
- name="Catalina">
- <Realm className="org.apache.catalina.realm.UserDatabaseRealm"/>
- <Host appBase="webapps" name="localhost">
- <Context path="/samples" docBase="D:\sdf\samples\WebRoot" debug="0" reloadable="true">
- <WatchedResource>WEB-INF/web.xml</WatchedResource>
- </Context>
- </Host>
- </Engine>
- </Service>
- </Server>