二 配置文件說明
TOMCAT的目錄結構linux
/bin:存放windows或Linux平臺上啓動和關閉Tomcat的腳本文件
/conf:存放Tomcat服務器的各類全局配置文件,其中最重要的是server.xml和web.xml
/server:包含三個子目錄:classes、lib和webapps
/server/lib:存放Tomcat服務器所需的各類JAR文件
/server/webapps:存放Tomcat自帶的兩個WEB應用admin應用和 manager應用
/common/lib:存放Tomcat服務器以及全部web應用均可以訪問的jar文件
/shared/lib:存放全部web應用均可以訪問的jar文件(可是不能被Tomcat服務器訪問)
/webapps:Tomcat的主要Web發佈目錄,默認狀況下把Web應用文件放於此目錄
TOMCAT的 web應用項目例子web
WEB應用的目錄結構:假設在$CATALINA_HOME/webapps下有helloapp的web應用
/helloapp:Web應用的根目錄,全部的jsp文件和html文件都在此目錄下
/helloapp/WEB_INF:存放該web應用發佈時的描述文件web.xml
/helloapp/WEB_INF/class:存放各類class文件,Servlet文件也存放於此目錄下
/helloapp/WEB_INF/lib:存放各鍾Web應用所須要的jar文件。好比能夠存放JDBC驅動程序的JAR文件
Tomcat加載類和資源的順序爲(以helloapp應用爲例)
helloapp (/webapps/helloapp/Web-INF/下的classes,lib子目錄中*.calss及*.jar,僅helloapp能夠加載)
Bootstrap ($JAVA_HOME/jre/lib/ext/*.jar)
System ($CLASSPATH/*.class和CLASSPATH中指定的jar)
Common ($CATALINA_HOME/common/下的classes,lib,endores子目錄中*.class及*.jar)
Catalina ($CATALINA_HOME/server/下的classes,lib子目錄中*.calss及*.jar,僅Tomcat能夠加載)
Shared ($CATALINA_HOME/shared/下的classes,lib子目錄中*.calss及*.jar,僅全部Web應用能夠加載)數據庫
$CATALINA_HOME/conf/server.xml結構層次與配置簡介apache
<Server>1
<Listener />2
<Listener />2
<GlobalNamingResources> 2
<Resource />
</GlobalNamingResources>2
<Service>2
<Connector/> 3
<Connector/> 3
<Engine> 3
<Logger />4
<Realm> 4
<Realm/>5
</Realm>4
<Host > 4
<Logger />5
<Context />5
</Host>4
</Engine>3
</Service>2
</Server>1vim
tomcat/conf/server.xml說明:windows
元素名瀏覽器 |
屬性 |
解釋 |
server |
port |
指定一個端口,這個端口負責監聽關閉tomcat 的請求 |
shutdown |
指定向端口發送的命令字符串 |
service |
name |
指定service 的名字,一般是」Catalina」 |
Connector ( 表示客戶端和service之間的鏈接) |
port |
指定服務器端要建立的端口號,並在這個斷口監聽來自客戶端的請求 |
minProcessors maxProcessors |
服務器啓動時建立的處理請求的線程數 最大能夠建立的處理請求的線程數 |
maxThreads minSpareThreads maxSpareThreads |
服務器建立的最大線程數 最小剩餘線程數 最大剩餘線程數 |
enableLookups |
若是爲true ,則能夠經過調用request.getRemoteHost() 進行DNS 查詢來獲得遠程客戶端的實際主機名,若爲false 則不進行DNS 查詢,而是返回其ip 地址 |
redirectPort |
指定服務器正在處理http 請求時收到了一個SSL 傳輸請求後重定向的端口號 |
acceptCount |
指定當全部可使用的處理請求的線程數都被使用時,能夠放處處理隊列中的請求數,超過這個數的請求將不予處理 |
connectionTimeout |
指定超時的時間數( 以毫秒爲單位) |
Engine ( 表示指定service 中的請求處理機,接收和處理來自Connector的請求) |
defaultHost |
指定缺省的處理請求的主機名,name:指定Engine的名字,一般是」Catalina」defaultHost:指定默認的處理請求的主機名,至少與某個host元素的name屬性值是相同的. |
Context ( 表示一個web 應用程序,一般爲WAR 文件,關於WAR 的具體信息見servlet 規範) |
docBase |
應用程序的路徑或者是WAR 文件存放的路徑 |
path |
表示此Web應用程序的url的入口,如爲「/hello「,則請求的URL爲http://localhost:8080/hello/reloadable:若是爲true,則Tomcat在運行時會自動監視Web應用的/WEB-INF/lib和/WEB-INF/classes下文件的改動,自動裝載新應用,使咱們能夠在不重啓Tomcat的狀況下更新Web應用 |
reloadable |
這個屬性很是重要,若是爲true ,則tomcat 會自動檢測應用程序的/WEB-INF/lib 和/WEB-INF/classes 目錄的變化,自動裝載新的應用程序,咱們能夠在不重起tomcat 的狀況下改變應用程序 |
host ( 表示一個虛擬主機 ) |
name debug truealias |
指定主機名 指定日誌級別 指定虛擬主機的別名,能夠指定多個別名 |
appBase |
應用程序基本目錄,即存放應用程序的目錄,相對路徑也能夠 |
unpackWARs deployOnStartup |
若是爲true,則tomcat會自動將WAR文件解壓後運行,不然不解壓而直接從WAR文件中運行應用程序autoDeploy:若是爲true,表示Tomcat啓動時會自動發佈appBase目錄下全部的Web應用(包括新加入的Web應用) 若是此項爲true,表示Tomcat服務器啓動時會自動發佈appBase目錄下全部Web應用。若是Web應用在server.xml中沒有相應的<Context>元素,則將採用默認的Context配置。deployOnStarup的默認設置是 |
Logger ( 表示日誌,調試和錯誤信息) |
className |
指定logger 使用的類名,此類必須實現org.apache.catalina.Logger 接口 |
prefix |
指定log 文件的前綴 |
suffix |
指定log 文件的後綴 |
timestamp txtdirectory: |
若是爲true ,則log 文件名中要加入時間,以下例:localhost_log.2001-10-04.txt 指定log文件存放的目錄 |
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>元素(第一層)
它表明整個容器,是Tomcat實例的頂層元素.由org.apache.catalina.Server接口來定義.它包含一個<Service>元素.而且它不能作爲任何元素的子元素.
<!-- 一個「Server」是一個提供完整的JVM的獨立組件,它能夠包含一個或多個「Service」實例。服務器在指定的端口上監聽shutdown命令。
注意:一個「Server」自身不是一個「Container」(容器),所以在這裏你不能夠定義諸如「Valves」或者「Loggers」子組件
啓動Server在端口8005處等待關閉命令若是接受到"SHUTDOWN"字符串則關閉服務器-->
<!-- 啓動Server在端口8005處等待關閉命令若是接受到"SHUTDOWN"字符串則關閉服務器
在端口8005處等待關閉命令若是接受到"SHUTDOWN"字符串則關閉服務器
若是接受到"SHUTDOWN"字符串則關閉服務器
-->
測試:
telnet localhost 8005
輸入:SHUTDOWN
結果:關閉tomcat
<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
6、URL管理
1、用戶配置
在進行具體Tomcat管理以前,先給tomcat添加一個用戶,使這個用戶有權限來進行管理。
打開conf目錄下的tomcat-users.xml文件,在相應的位置添加下面一行:
<user name="user" password="user" roles="standard,manager"/>
而後重起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
上面顯示的信息分別爲:應用程序的路徑、當前狀態、鏈接這個程序的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應用程序。
六、開啓tomcat的監控
1)、tomcat6的配置
修改tomcat/conftomcat-users.xml文件中</tomcat-users>節點以前添加以下代碼便可。
<user name="user" password="user" roles="manager"/>
2)tomcat7的配置
修改tomcat/conftomcat-users.xml文件中</tomcat-users>節點以前添加以下代碼便可。
<role rolename="manager-gui"/>
<user username="user" password="user" roles="manager-gui"/>
而後輸入而後訪問http://serverip:8080/manager/status便可訪問。