TOMCAT虛擬主機配置

1.設置本地主機域名
    Hosts是一個沒有擴展名的系統文件,可以用記事本等工具打開,其作用就是將一些常用的網址域名與其對應的IP地址建立一個關聯“數據庫”,當用戶在瀏 覽器中輸入一個需要登錄的網址時,系統會首先自動從Hosts文件中尋找對應的IP地址,一旦找到,系統會立即打開對應網頁,如果沒有找到,則系統再會將 網址提交DNS域名解析服務器進行IP地址的解析。
通過修改本地主機上的一個hosts文件,可以進行對ip地址與本地域名的映射,從而解決在本地調試JSP項目的時候,通過本地域名進行訪問。
    hosts文件在系統目錄C:/WINDOWS/system32/drivers/etc/下,這個目錄不容易記憶,如果要經常修改這個文件的話不是很 方便找,可以 建立一個批處理hosts.bat文件,用文本編輯器打開,寫入內容explorer "C:/WINDOWS/system32/drivers/etc",保存退出,可以把這個hosts.bat文件放在桌面,每次雙擊它就能打開 hosts文件所在的目錄。也可以將hosts.bat文件放到C:/WINDOWS下,這樣,每次只要從點“開始”->“運行”,輸入 hosts,點回車就可以打開hosts文件所在的目錄了,另外在命令行也可以輸入hosts打開hosts文件所在的目錄。
找到hosts文件後,用文本編輯器打開,默認狀態下,hosts文件裏只有一個映射關係:
    127.0.0.1       localhost
按照這個格式再添加一個映射:
    xxx.xxx.xxx.xxx www.xxxx.com
保存,退出。這時候本地IP地址202.112.113.171已經和www.xxxx.com 這個本地域名做了對應的映射關係。

2.server.xml配置簡介
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方式記錄的值更多
3.配置虛擬主機(Virtual Hosts)
       關於server.xml中“Host”這個元素,只有在你設置虛擬主機的才需要修改。虛擬主機是一種在一個web服務器上服務多個域名的機制,對每個域名而言,都好象獨享了整個主機 。實際上,大多數的小型商務網站都是採用虛擬主機實現的,這主要是因爲虛擬主機能直接連接到Internet並提供相應的帶寬,以保障合理的訪問響應速度,另外虛擬主機還能提供一個穩定的固定IP。
   基於名字的虛擬主機可以被建立在任何web服務器上,建立的方法就是通過在域名服務器(DNS)上建立IP地址的別名,並且告訴web服務器把去往不同 域名的請求分發到相應的網頁目錄。在Tomcat中使用虛擬主機,需要設置DNS或主機數據。在server.xml中設置內容,如下:

<
Server
 port
="8005"
 shutdown
="SHUTDOWN"
 debug
="0"
>
 
< Service name ="Tomcat-Standalone" >
< Connector className ="org.apache.coyote.tomcat4.CoyoteConnector" port ="80" minProcessors ="5" maxProcessors ="75" enableLookups ="true" redirectPort ="8443" />
< Connector className ="org.apache.coyote.tomcat4.CoyoteConnector" port ="8443" minProcessors ="5" maxProcessors ="75" acceptCount ="10" debug ="0" scheme ="https" secure ="true" />
< Factory className ="org.apache.coyote.tomcat4.CoyoteServerSocketFactory" clientAuth ="false" protocol ="TLS" />
</ Connector >
< Engine name ="Standalone" defaultHost ="localhost" debug ="0" >
<!-- This Host is the default Host -->
< Host name ="localhost" debug ="0" appBase ="webapps" unpackWARs ="true" autoDeploy ="true" >
< Context path ="" docBase ="ROOT" debug ="0" />
< Context path ="/orders" docBase ="/orders" debug ="0" reloadable ="true" crossContext ="true" >
</ Context >
</ Host >

<!-- This Host is the first "Virtual Host": http://www.yujiaxin.com -->
< Host name ="www.yujiaxin.com" appBase ="webapps" unpackWARs ="true" autoDeploy ="true" xmlValidation ="false" xmlNamespaceAware ="false" >
< Context docBase ="jspwebsite" path ="" reloadable ="true" />
</ Host >

</ Engine >
</ Service >
</ Server >

  Tomcat的server.xml文件,在初始狀態下,只包括一個虛擬主機,但是它容易被擴充到支持多個虛擬主機。增加虛擬主機只要增加完整 Host標籤即可。每一個Host元素必須包括一個或多個context元素,所包含的context元素中必須有一個是默認的context,這個默認 的context的顯示路徑應該爲空(例如,path="")。

 

概述

元素名

屬性

解釋

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方式記錄的值更多



<Server>元素

它代表整個容器,是Tomcat實例的頂層元素.由org.apache.catalina.Server接口來定義.它包含一 個<Service>元素.並且它不能做爲任何元素的子元素.<Server port="8005" shutdown="SHUTDOWN" debug="0">
1>className指定實現org.apache.catalina.Server接口的類.默認值爲org.apache.catalina.core.StandardServer
2>port指定Tomcat監聽shutdown命令端口.終止服務器運行時,必須在Tomcat服務器所在的機器上發出shutdown命令.該屬性是必須的.
3>shutdown指定終止Tomcat服務器運行時,發給Tomcat服務器的shutdown監聽端口的字符串.該屬性必須設置

<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

發佈了60 篇原創文章 · 獲贊 3 · 訪問量 6萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章