【積累】關於tomcat配置

        平時用tomcat只是單純的用它的服務,但是現在手頭這個案子,需要探討tomcat的安全性的問題,所以需要再進一步研究,現在把tomcat 服務器構架記下來,已備使用。
 <wbr>tomcat最新版本爲5.5.9,下載地址:http://java.sun.com/products/jsp/tomcat/
 <wbr>一、安裝和配置
 <wbr>在安裝之前,請確保機器上已經安裝了最新的JDK。
 <wbr>按照一般的windows程序安裝步驟即可安裝好tomcat,安裝時它會自動尋找你的jdk和jre的位置。
 <wbr>運行tomcat需要設置JAVA_HOME變量 <wbr>
set <wbr>JAVA_HOME=c:/jdk <wbr>(win98,在msdos方式下使用,或者放入autoexec.bat中) <wbr>
export <wbr>JAVA_HOME=/usr/local/jdk <wbr>(linux下使用,放到/etc/bashrc或者/etc/profile中) <wbr>
 <wbr>二、應用 <wbr>

(一):目錄結構 <wbr>
tomcat的目錄結構如下: <wbr>
目錄名: <wbr>簡介 <wbr>
bin <wbr>: <wbr>存放啓動和關閉tomcat腳本 <wbr>
conf <wbr>: <wbr>包含不同的配置文件,server.xml(Tomcat的主要配置文件)和web.xml <wbr>
work <wbr>: <wbr>存放jsp編譯後產生的class文件 <wbr>
webapp: <wbr>存放應用程序示例,以後你要部署的應用程序也要放到此目錄 <wbr>
logs <wbr>: <wbr>存放日誌文件 <wbr>
lib/japser/common <wbr>: <wbr>這三個目錄主要存放tomcat所需的jar文件 <wbr>


(二):server.xml配置簡介 <wbr>
下面我們將講述這個文件中的基本配置信息,更具體的配置信息見tomcat的文
檔 <wbr>
server: <wbr>
port <wbr>指定一個端口,這個端口負責監聽關閉tomcat的請求 <wbr>
shutdown <wbr>指定向端口發送的命令字符串 <wbr>
service: <wbr>
name <wbr>指定service的名字 <wbr>
Connector <wbr>(表示客戶端和service之間的連接): <wbr>
port <wbr>指定服務器端要創建的端口號,並在這個斷口監聽來自客戶端的請求 <wbr>
minProcessors <wbr>服務器啓動時創建的處理請求的線程數 <wbr>
maxProcessors <wbr>最大可以創建的處理請求的線程數 <wbr>
enableLookups <wbr>如果爲true,則可以通過調用request.getRemoteHost()進
行DNS查詢來得到遠程客戶端的實際主機名,若爲false則不進行DNS查詢,而是
返回其ip地址 <wbr>
redirectPort <wbr>指定服務器正在處理http請求時收到了一個SSL傳輸請求後重定向
的端口號 <wbr>
acceptCount <wbr>指定當所有可以使用的處理請求的線程數都被使用時,可以放到處
理隊列中的請求數,超過這個數的請求將不予處理 <wbr>
connectionTimeout <wbr>指定超時的時間數(以毫秒爲單位) <wbr>
Engine <wbr>(表示指定service中的請求處理機,接收和處理來自Connector的請
求): <wbr>
defaultHost <wbr>指定缺省的處理請求的主機名,它至少與其中的一個host元素的
name屬性值是一樣的 <wbr>
Context <wbr>(表示一個web應用程序,通常爲WAR文件,關於WAR的具體信息見
servlet規範): <wbr>
docBase <wbr>應用程序的路徑或者是WAR文件存放的路徑 <wbr>
path <wbr>表示此web應用程序的url的前綴,這樣請求的url爲
http://localhost:8080/path/**** <wbr>
reloadable <wbr>這個屬性非常重要,如果爲true,則tomcat會自動檢測應用程序
的/WEB-INF/lib <wbr>和/WEB-INF/classes目錄的變化,自動裝載新的應用程序,
我們可以在不重起tomcat的情況下改變應用程序 <wbr>

host <wbr>(表示一個虛擬主機): <wbr>
name <wbr>指定主機名 <wbr>
appBase <wbr>應用程序基本目錄,即存放應用程序的目錄 <wbr>
unpackWARs <wbr>如果爲true,則tomcat會自動將WAR文件解壓,否則不解壓,
直接從WAR文件中運行應用程序 <wbr>
Logger <wbr>(表示日誌,調試和錯誤信息): <wbr>
className <wbr>指定logger使用的類名,此類必須實現
org.apache.catalina.Logger <wbr>接口 <wbr>
prefix <wbr>指定log文件的前綴 <wbr>
suffix <wbr>指定log文件的後綴 <wbr>
timestamp <wbr>如果爲true,則log文件名中要加入時間,如下
例:localhost_log.2001-10-04.txt <wbr>
Realm <wbr>(表示存放用戶名,密碼及role的數據庫): <wbr>
className <wbr>指定Realm使用的類名,此類必須實現org.apache.catalina.Realm接口 <wbr>
Valve <wbr>(功能與Logger差不多,其prefix和suffix屬性解釋和Logger <wbr>中的一
樣): <wbr>
className <wbr>指定Valve使用的類名,如用org.apache.catalina.valves.AccessLogValve類可以記錄應用程序的訪問信
息 <wbr>
directory <wbr>指定log文件存放的位置 <wbr>
pattern <wbr>有兩個值,common方式記錄遠程主機名或ip地址,用戶名,日期,第
一行請求的字符串,HTTP響應代碼,發送的字節數。combined方式比common
方式記錄的值更多 <wbr>

注意: <wbr>
1:經過我測試,我設置Context <wbr>的path="",reloadable=true,然後放一個
WAR文件到webapps目錄,結果tomcat不能檢測出此文件(重起tomcat可
以),而把此文件解壓,則tomcat會自動檢測出這個新的應用程序。如果不能自動
檢測WAR文件,我們可以利用下面管理中講的方法來部署應用程序。 <wbr>


2:默認的server.xml中,Realm元素只設置了一個className屬性,但此文件
中也包含幾個通過JDBC連接到數據庫進行驗證的示例(被註釋掉了),通過Realm
元素我們可以實現容器安全管理(Container <wbr>Managed <wbr>Security)。 <wbr>


3:還有一些元素我們沒有介紹,如Parameter,loader,你可以通過tomcat
的文檔獲取這些元素的信息。 <wbr>
三、管理
1:配置 <wbr>
在進行具體的管理之前,我們先給tomcat添加一個用戶,使這個用戶有權限來進
行管理。 <wbr>
打開conf目錄下的tomcat-users.xml文件,在相應的位置添加下面一行: <wbr>


<user <wbr>name="zf" <wbr>password="zf" <wbr>roles="standard,manager"/> <wbr>


注意:這一行的最後部分一定是/>,tomcat的文檔掉了/符號,如果沒有/符號的
話,tomcat重起時將無法訪問應用程序。通過logs/catalina.out文件你可以看
到這個錯誤的詳細信息。 <wbr>


然後重起tomcat,在瀏覽器中輸入http://localhost:8080/manager/,會彈
出對話框,輸入上面的用戶名和密碼即可。
 <wbr>

2:應用程序列表 <wbr>
在瀏覽器中輸入http://localhost:8080/manager/list,瀏覽器將會顯示如下
的信息: <wbr>

OK <wbr>- <wbr>Listed <wbr>applications <wbr>for <wbr>virtual <wbr>host <wbr>localhost <wbr>
/ex:running:1 <wbr>
/examples:running:1 <wbr>
/webdav:running:0 <wbr>
/tomcat-docs:running:0 <wbr>
/manager:running:0 <wbr>
/:running:0 <wbr>

上面的信息分別爲應用程序的路徑,當前狀態(running <wbr>或者stopped),與這個
程序相連的session數。 <wbr>

3:重新裝載應用程序 <wbr>
在瀏覽器中輸入 <wbr>http://localhost:8080/manager/reload?
path=/examples,瀏覽器顯示如下: <wbr>

OK <wbr>- <wbr>Reloaded <wbr>application <wbr>at <wbr>context <wbr>path <wbr>/examples <wbr>

表示example應用程序裝載成功,如果我們將server.xml的Context元素的
reloadable屬性設爲true(見上面表格),則沒必要利用這種方式重新裝載應用程
序,因爲tomcat會自動裝載。 <wbr>

4:顯示session信息 <wbr>
在瀏覽器中輸入http://localhost:8080/manager/sessions?
path=/examples,瀏覽器顯示如下: <wbr>

OK <wbr>- <wbr>Session <wbr>information <wbr>for <wbr>application <wbr>at <wbr>context <wbr>path <wbr>/examples
 <wbr>Default <wbr>maximum <wbr>session <wbr>inactive <wbr>interval <wbr>30 <wbr>minutes <wbr>

5:啓動和關閉應用程序 <wbr>
在瀏覽器中輸入http://localhost:8080/manager/start?path=/examples
http://localhost:8080/manager/stop?path=/examples分別啓動和關
閉examples應用程序。 <wbr>

6:部署及撤銷部署 <wbr>
WAR有兩種組織方式,一種是按一定的目錄結構組織文件,一種是一個後綴爲
WAR的壓縮包,因此它的部署方式也有兩種: <wbr>
(1):在瀏覽器中輸入:http://localhost:8080/manager/install?
path=/examples&war=file:/c:examples <wbr>

就會將按目錄結構組織的WAR部署 <wbr>


(2):如果輸入:http://localhost:8080/manager/install?path=/examples&war=jar:file:/c:examples.war!/ <wbr>
就會將按壓縮包組織的WAR部署,注意此url後半部分一定要有!/號。 <wbr>
部署後就可以用 <wbr>http://localhost:8080/examples訪問了。 <wbr>

在瀏覽器中輸入:http://localhost:8080/manager/remove?path=/examples <wbr>就會撤銷剛纔部署的應用程序。 <wbr>
 <wbr>
四、與apache集成 <wbr>
雖然tomcat也可以作web服務器,但其處理靜態html的速度比不上apache,且其
作爲web服務器的功能遠不如apache,因此我們想把apache和tomcat集成起
來。 <wbr>
我們以linux系統爲例介紹. <wbr>
從apache網站下載apache1.3.22源代碼版本,然後使用如下命令配置安裝
apache: <wbr>

mkdir <wbr>/usr/local/apache <wbr>
tar <wbr>zxvf <wbr>apache.1.32.tar.gz <wbr>
cd <wbr>apache.1.32 <wbr>
./configure <wbr>--prefix=/usr/local/apache <wbr>--enable-module=so <wbr>
make <wbr>
make <wbr>install <wbr>

注意configure命令指定目標安裝目錄,並且加入DSO(Dynamic <wbr>Shared <wbr>
Object)支持,注意一定不要忘了這一個選項。 <wbr>

然後下載webapp模塊,將解壓後mod_webapp.so文件放入apache的
libexec目錄,編輯apache的conf目錄下的httpd.conf,在這個文件的最後加入
下面三行: <wbr>

LoadModule <wbr>webapp_module <wbr>libexec/mod_webapp.so <wbr>
WebAppConnection <wbr>warpConnection <wbr>warp <wbr>localhost:8008 <wbr>
WebAppDeploy <wbr>examples <wbr>warpConnection <wbr>/examples/ <wbr>

第一行是加入webapp模塊,如果編譯apache時不增加DSO支持,則無法使用
LoadModule指令,第二行指定tomcat與apache的連接,第三行指定部署那個
應用,這兩個指令使用格式如下: <wbr>

WebAppConnection <wbr>[connection <wbr>name] <wbr>[provider] <wbr>[host:port] <wbr>
WebAppDeploy <wbr>[application <wbr>name] <wbr>[connection <wbr>name] <wbr>[url <wbr>path] <wbr>

其中connection <wbr>name指定連接名,provider只能是warp,port端口與你的
tomcat的配置文件server.xml最後幾行指定的要保持一致。文件如下: <wbr>


<Service <wbr>name="Tomcat-Apache"> <wbr>
<Connector <wbr>className="org.apache.catalina.connector.warp.WarpConnector" <wbr>
port="8008" <wbr>minProcessors="5" <wbr>maxProcessors="75" <wbr>
enableLookups="true" <wbr>
acceptCount="10" <wbr>debug="0"/> <wbr>
****** <wbr>
</Service> <wbr>

application <wbr>name與你在tomcat中部署的應用名一致,url <wbr>path指定訪問這個
應用的url。例如上面的例子可以通過http://localhost/examples/來訪問
tomcat中的examples應用。 <wbr>
五、中文問題 <wbr>
一般jsp的亂碼問題可以通過在jsp中加入<%@ <wbr>page <wbr>contentType="text/html;charset=GB2312" <wbr>%>來解決,至於servlet的亂
碼在可以使用servlet2.3中提供的HttpServeletRequest.setCharacterEncoding函數。更詳細的中文問題請見
JSP/Servlet <wbr>中的漢字編碼問題。
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章