tomcat安裝與配置文件

一 安裝tomcat
1.系統必須已安裝配置JDK
安裝說明參考地址:http://www.cnblogs.com/Yuanbangchen/p/5945491.html
 
2.將apache-tomcat-8.0.29.tar.gz文件上傳到/usr/local中執行如下操做
將上傳的Tomcat8.0解壓,解壓以後重命名爲tomcat.
tar -zxv -f apache-tomcat-8.0.29.tar.gz
mv apache-tomcat-8.0.29 tomcat
 
3.啓動tomcat
/usr/local/tomcat/bin/startup.sh
/usr/local/tomcat/bin/shutdown.sh   //中止tomcat  
 

服務器啓動和關閉vim /etc/rc.d/init.d/tomcat

#!/bin/bash
# /etc/rc.d/init.d/tomcat
# init script for tomcat precesses
# processname: tomcat
# description: tomcat is a j2se server
# chkconfig: 2345 86 16
# description: Start up the Tomcat servlet engine.html

if [ -f /etc/init.d/functions ]; then
. /etc/init.d/functions
elif [ -f /etc/rc.d/init.d/functions ]; then
. /etc/rc.d/init.d/functions
else
echo -e "\atomcat: unable to locate functions lib. Cannot continue."
exit -1
fi
RETVAL=$?
CATALINA_HOME="/usr/local/kencery/tomcat" #tomcat安裝目錄,你安裝在什麼目錄下就複製什麼目錄
case "$1" in
start)
if [ -f $CATALINA_HOME/bin/startup.sh ];
then
echo $"Starting Tomcat"
$CATALINA_HOME/bin/startup.sh
fi
;;
stop)
if [ -f $CATALINA_HOME/bin/shutdown.sh ];
then
echo $"Stopping Tomcat"
$CATALINA_HOME/bin/shutdown.sh
fi
;;
*)
echo $"Usage: $0 {start|stop}"
exit 1
;;
esac
exit $RETVAL前端

Linuxjava

給文件添加權限,使得腳本文件能夠執行,命令爲 chmod 755 /etc/rc.d/init.d/tomcat
將其添加到服務中,命令爲 chkconfig --add /etc/rc.d/init.d/tomcat
而後將下面的配置文件加到tomcat中的catalina.sh文件中的最後面,命令爲:vim /usr/local/kencery/tomcat/bin/catalina.sh
    export JAVA_HOME=/usr/local/kencery/javajdk #javajdk的安裝路徑,使用echo $JAVA_HOME命令能夠讀取
    export CATALINA_HOME=/usr/local/kencery/tomcat
    export CATALINA_BASE=/usr/local/kencery/tomcat
    export CATALINA_TMPDIR=/usr/local/kencery/tomcat/temp
以上全部工做順利進行而且沒有報錯,則配置完成,你能夠輸入命令service tomcat start和service tomcat stop

設置tomcat的開機啓動

 經過第三步的設置咱們能夠很方便的設置tomcat的啓動和關閉,可是這裏存在一個問題,那就是當服務器關機重啓的時候,服務不能隨計算機的啓動而本身啓動,那麼咱們能夠將tomcat服務設置爲開機啓動。
打開linux設置開啓啓動的文件,將下面的配置文件寫入此文件的最後,命令爲:vim /etc/rc.d/rc.local
    export JAVA_HOME=/usr/local/kencery/javajdk
    export CLASSPATH=.:$JAVA_HOME/jre/lib/rt.jar:$JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar
    export PATH=$PATH:$JAVA_HOME/bin
    export CATALINA_HOME=/usr/local/kencery/tomcat/
    #tomcat自啓動
    /usr/local/kencery/tomcat/bin/startup.
  tomcat依賴於Java的jdk,因此設置的時候講jdk也同步導入。
 
 
 
防火牆設設置     或者編輯配件文件/vim /etc/sysconfig/iptables
iptables -A INPUT -p tcp --dport 8080 -j ACCEPT
iptables -A OUTPUT -p tcp --sport 8080 -j ACCEPT
service iptables save
 
5.檢驗Tomcat安裝運行
http://x.x.x.x:8080
二 配置文件說明

TOMCAT的目錄結構linux

    /bin:存放windows或Linux平臺上啓動和關閉Tomcat的腳本文件
    /conf:存放Tomcat服務器的各類全局配置文件,其中最重要的是server.xml和web.xml
    /doc:存放Tomcat文檔
    /server:包含三個子目錄:classes、lib和webapps
    /server/lib:存放Tomcat服務器所需的各類JAR文件
    /server/webapps:存放Tomcat自帶的兩個WEB應用admin應用和 manager應用
    /common/lib:存放Tomcat服務器以及全部web應用均可以訪問的jar文件
    /shared/lib:存放全部web應用均可以訪問的jar文件(可是不能被Tomcat服務器訪問)
    /logs:存放Tomcat執行時的日誌文件
    /src:存放Tomcat的源代碼
    /webapps:Tomcat的主要Web發佈目錄,默認狀況下把Web應用文件放於此目錄
    /work:存放JSP編譯後產生的class文件

 

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.xmlContext元素的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便可訪問。

20151228100110706.png (1122×679)

相關文章
相關標籤/搜索