一、小貓TOMCAT其實很可愛
2003年底,我換公司了,同樣也換了WEBAPP,TOMCAT出現在我的面前(以前使用weblogic),我有點茫然,免費的東西真的能用的好么?擔心ING……(其實是在火星呆太久)出門一打聽,原來此貓出自名門-jakarta項目,2001年度最具創新的java產品(Most Innovative Java Product),又有JAVA的老大SUN的力捧(官方推薦的servlet和jsp容器),以后就靠它吃飯了。不說二話,搞起來先:
1、??安裝
TOMCAT最新版本是5.0.29( http://jakarta.apache.org/site/binindex.cgi )
如果在WINDOWS下它可以自動找到你的JDK或者set JAVA_HOME=c:/jdk
在LINUX下需要先解壓,然后設置JAVA_HOME
export JAVA_HOME=/usr/local/jdk
2、??RUN
設置完畢后就可以運行tomcat服務器了,進入tomcat的bin目錄,WINDOWS下用startup啟動tomcat,linux下用startup.sh,相應的關閉tomcat的命令為shutdown和shutdown.sh。
啟動服務后在瀏覽器里輸入 http://localhost:8080/ 來測試一下
3、??目錄結構
Bin:存放啟動和關閉tomcat腳本。
Conf:包含不同的配置文件,server.xml(Tomcat的主要配置文件)。
Work:存放jsp編譯后產生的class文件。
Webapp:存放應用程序示例,以后你要部署的應用程序也要放到此目錄。
Logs:存放日志文件
Comm./server/shared:這三個文件夾下的LIB文件夾放jar文件。
1、??配置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方式記錄的值更多 |
?
?
<Context path="/hello" docBase="E:/workspace/hello/WebRoot" debug="0" privileged="true">
</Context>?
Context 節點屬性,可詳細見相關文檔。
第二種方法:將web項目文件件拷貝到webapps 目錄中。
第三種方法:很靈活,在conf目錄中,新建 Catalina\localhost目錄,在該目錄中新建一個xml文件,
名字不可以隨意取,要和path后的那個名字一致,按照下邊這個path的配置,xml的名字應該就應該是hello
,該xml文件的內容為:
<Context path="/hello" docBase="E:/workspace/hello/WebRoot" debug="0" privileged="true">
</Context>??
前三種是轉貼
第四種方法 在eclipse中點啟動tomcat那個按鈕左邊那個按鈕
可以按照步驟deploy
很簡單
個人喜歡第三種方法 但是從別人那轉貼過來的時候被騙了 暈 紅字部分標明了我修改過的
?
?
啟動調試模式:
打開Tomcat?5.0\conf\Catalina\localhost
路徑下的工程配置xml文件
---------------
<Context?path="/admin"?docBase="E:\project1\practice\practice"
????????debug="0"?privileged="true">
</Context>
------------------------
其中debug屬性?與這個Engine關聯的Logger記錄的調試信息的詳細程度。數字越大,輸出越詳細。如果沒有指定,缺省為0。
?
更多文章、技術交流、商務合作、聯系博主
微信掃碼或搜索:z360901061

微信掃一掃加我為好友
QQ號聯系: 360901061
您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對您有幫助就好】元
