Tomcat工作原理之檔案配置詳解
一、Tomcat目錄
|---bin:存放啟動和關閉tomcat指令碼;
|---conf:存放不同的配置檔案(server.xml和web.xml);
|---doc:存放Tomcat文件;
|---lib/japser/common:存放Tomcat執行需要的庫檔案(JARS);
|---logs:存放Tomcat執行時的LOG檔案;
|---src:存放Tomcat的原始碼;
|---webapps:Tomcat的主要Web釋出目錄(包括應用程式示例);
|---work:存放jsp編譯後產生的class檔案;
二、Server.XML
程式碼:
<?xmlversion='1.0' encoding='utf-8'?> <Serverport="8005" shutdown="SHUTDOWN"> <ListenerclassName="org.apache.catalina.startup.VersionLoggerListener" /> <ListenerclassName="org.apache.catalina.core.AprLifecycleListener"SSLEngine="on" /> <ListenerclassName="org.apache.catalina.core.JasperListener" /> <ListenerclassName="org.apache.catalina.core.JreMemoryLeakPreventionListener"/> <ListenerclassName="org.apache.catalina.mbeans.GlobalResourcesLifecycleListener"/> <ListenerclassName="org.apache.catalina.core.ThreadLocalLeakPreventionListener"/> <GlobalNamingResources> <Resource name="UserDatabase"auth="Container" type="org.apache.catalina.UserDatabase" description="User databasethat can be updated and saved" factory="org.apache.catalina.users.MemoryUserDatabaseFactory" pathname="conf/tomcat-users.xml" /> </GlobalNamingResources> <Service name="Catalina"> <Connector port="8080"protocol="HTTP/1.1" connectionTimeout="20000" redirectPort="8443"/> <Connector port="8009"protocol="AJP/1.3" redirectPort="8443" /> <Engine name="Catalina"defaultHost="localhost"> <RealmclassName="org.apache.catalina.realm.LockOutRealm"> <RealmclassName="org.apache.catalina.realm.UserDatabaseRealm" resourceName="UserDatabase"/> </Realm> <Host name="localhost" appBase="webapps" unpackWARs="true"autoDeploy="true"> <ValveclassName="org.apache.catalina.valves.AccessLogValve"directory="logs" prefix="localhost_access_log." suffix=".txt" pattern="%h%l%u%t"%r" %s %b" /> </Host> </Engine> </Service> </Server>
含義:
server:
1、port 指定一個埠,這個埠負責監聽關閉tomcat的請求
2、shutdown 指定向埠傳送的命令字串
service: 1、name 指定service的名字
Connector (表示客戶端和service之間的連線):
1、port 指定伺服器端要建立的埠號,並在這個斷口監聽來自客戶端的請求
2、minProcessors 伺服器啟動時建立的處理請求的執行緒數
3、maxProcessors 最大可以建立的處理請求的執行緒數
4、enableLookups 如果為true,則可以通過呼叫request.getRemoteHost()進行DNS查詢來得到遠端客戶端的實際主機名,若為false則不進行DNS查詢,而是返回其ip地址
5、redirectPort 指定伺服器正在處理http請求時收到了一個SSL傳輸請求後重定向的埠號
6、acceptCount 指定當所有可以使用的處理請求的執行緒數都被使用時,可以放到處理佇列中的請求數,超過這個數的請求將不予處理
7、connectionTimeout 指定超時的時間數(以毫秒為單位)
Engine
1、defaultHost 指定預設的處理請求的主機名,它至少與其中的一個host元素的name屬性值是一樣的
Context (表示一個web應用程式):
1、docBase 應用程式的路徑或者是WAR檔案存放的路徑
2、path 表示此web應用程式的url的字首,這樣請求的url為http://localhost:8080/path/****
3、reloadable 這個屬性非常重要,如果為true,則tomcat會自動檢測應用程式的
host (表示一個虛擬主機):
1、name 指定主機名
2、appBase 應用程式基本目錄,即存放應用程式的目錄
3、unpackWARs 如果為true,則tomcat會自動將WAR檔案解壓,否則不解壓,直接從WAR檔案中執行應用程式
4、autoDeploy如果此項設為true,表示Tomcat服務處於執行狀態時,能夠監測appBase下的檔案,如果有新有web應用加入進來,會自運釋出這個WEB應用
Logger (表示日誌,除錯和錯誤資訊):
1、className 指定logger使用的類名,此類必須實現org.apache.catalina.Logger 介面
2、prefix 指定log檔案的字首
3、suffix 指定log檔案的字尾
4、timestamp 如果為true,則log檔名中要加入時間,如下例:localhost_log.2001-10-04.txt
Realm (表示存放使用者名稱,密碼及role的資料庫):
1、className 指定Realm使用的類名,此類必須實現org.apache.catalina.Realm介面
Valve (功能與Logger差不多,其prefix和suffix屬性解釋和Logger 中的一樣):
1、className 指定Valve使用的類名,如用org.apache.catalina.valves.AccessLogValve類可以記錄應用程式的訪問資訊
directory(指定log檔案存放的位置):
1、pattern 有兩個值,common方式記錄遠端主機名或ip地址,使用者名稱,日期,第一行請求的字串,HTTP響應程式碼,傳送的位元組數。combined方式比common方式記錄的值更多
三、Web.XML
1、預設(歡迎)檔案的設定
在tomcat7\conf\web.xml中,<welcome-file-list>與IIS中的預設檔案意思相同。
<welcome-file-list>
<welcome-file>index.html</welcome-file>
<welcome-file>index.htm</welcome-file>
<welcome-file>index.jsp</welcome-file>
</welcome-file-list>
2、報錯檔案的設定
<error-page>
<error-code>404</error-code>
<location>/notFileFound.jsp</location>
</error-page>
<error-page>
<exception-type>java.lang.NullPointerException</exception-type>
<location>/null.jsp</location>
</error-page>
如果某檔案資源沒有找到,伺服器要報404錯誤,按上述配置則會呼叫\webapps\ROOT\notFileFound.jsp。
如果執行的某個JSP檔案產生NullPointException,則會呼叫\webapps\ROOT\null.jsp
3、會話超時的設定
設定session 的過期時間,單位是分鐘;
<session-config>
<session-timeout>30</session-timeout>
</session-config>
4、過濾器的設定
<filter> <filter-name>FilterSource</filter-name> <filter-class>project4.FilterSource</filter-class> </filter> <filter-mapping> <filter-name>FilterSource</filter-name> <url-pattern>/WwwServlet</url-pattern> (<url-pattern>/haha/*</url-pattern>) </filter-mapping> <filter-name>FilterSource</filter-name> <filter-class>project4.FilterSource</filter-class> </filter> <filter-mapping> <filter-name>FilterSource</filter-name> <url-pattern>/WwwServlet</url-pattern> (<url-pattern>/haha/*</url-pattern>) </filter-mapping>
過濾:
1) 身份驗證的過濾AuthenticationFilters
2) 日誌和稽核的過濾Loggingand AuditingFilters
3) 圖片轉化的過濾ImageconversionFilters
4) 資料壓縮的過濾DatacompressionFilters
5) 加密過濾EncryptionFilters
6)Tokenizing Filters
7) 資源訪問事件觸發的過濾Filtersthat triggerresource access events XSL/T 過濾XSL/T filters
8) 內容型別的過濾Mime-typechain Filter 注意監聽器的順序,如:先安全過濾,然後資源,
然後內容型別等,這個順序可以自己定。