Tomcat之虚拟主机配置以及web应用配置

Tomcat之虚拟主机配置以及web应用配置


Tomcat文件夹结构例如以下:

bin ---- 启动和关闭须要的bat文件所在的文件夹

conf --- 配置文件夹

lib ---  tomcat执行时须要的jar包所在的文件夹

logs --- 执行时产生的日志信息所在的文件夹

temp --- tomcat执行时产生的暂时文件存放的文件夹,不须要我们管理

webapps --- 开发中最经常使用的文件夹,web应用放置到此文件夹下浏览器能够直接訪问

work --- 工作文件夹,tomcat执行时产生的工作文件存放在这个文件夹中

一、基本概念


虚拟主机的简单理解:

在一台Tomcatserver中能够同一时候管理多个站点。即能够将多个站点配置在同一台Tomcatserver上。而对于用户(浏览器)而言,是不知道详细哪些站点是布置在同一台Tomcat(server)之上的。对于用户(浏览器)而言,每一个站点都像是执行在各自独立的server上。此时每一个站点就是执行在同一台这是server中各自相应的虚拟主机上。此时,简单的理解。每一个站点就能够觉得是一个虚拟主机。

Web应用:

一个Web应用程序是由完毕特定任务的各种Web组件(web components)构成的并通过Web将服务展示给外界。

在实际应用中,Web应用程序是由多个ServletJSP页面、HTML文件以及图像文件等web资源组成。而这些web资源不能直接交给虚拟主机,故将这些资源依照一定的格式组织成web应用交由虚拟机主机管理。

全部这些组件相互协调为用户提供一组完整的服务。 

简单的将:web应用就是依照特定格式组织的一些web资源(ServletJSP页面、HTML文件以及图像文件等)的集合,为用户提供特定服务。

一个Tomcat中能够配置多个虚拟主机,一个虚拟主机中能够配置多个web应用。


二、Tomcat虚机主机配置


conf/server.xml<Engin>标签下配置<Host>标签就能够为tomcat添加一台虚拟主机了

name -- 指定虚拟主机的名称,浏览器通过这个名称訪问虚拟主机

appBase -- 虚拟主机管理的文件夹,放置在这个文件夹下的web应用当前虚拟主机能够自己主动载入(在autoDeploytrue的情况下)相当于Localhost虚拟主机的webapps文件夹(在autoDeploytrue的情况下)

debug -- 是日志的调试等级       
unpackWARs -- 设置为true,Web应用为*.war,解压此WAR文件假设为true,tomcat会自己主动将WAR文件解压;否则不解压,直接从WAR文件里执行应用程序.      
autoDeploy -- 默觉得true,表示假设有新的WEB应用放入appBase 而且Tomcat在执行的情况下,自己主动加载应用

实例代码:

</pre><pre>

<?xml version="1.0" encoding="UTF-8"?>
<Server port="8005" shutdown="SHUTDOWN">
  <Listener className="org.apache.catalina.startup.VersionLoggerListener"/>  
  <Listener SSLEngine="on" className="org.apache.catalina.core.AprLifecycleListener"/>  
  <Listener className="org.apache.catalina.core.JasperListener"/>  
  <Listener className="org.apache.catalina.core.JreMemoryLeakPreventionListener"/>
  <Listener className="org.apache.catalina.mbeans.GlobalResourcesLifecycleListener"/>
  <Listener className="org.apache.catalina.core.ThreadLocalLeakPreventionListener"/>
 
  <GlobalNamingResources>
   
    <Resource auth="Container" description="User database that can be updated and saved" factory="org.apache.catalina.users.MemoryUserDatabaseFactory" name="UserDatabase" pathname="conf/tomcat-users.xml" type="org.apache.catalina.UserDatabase"/>
  </GlobalNamingResources>
  
  <Service name="Catalina">
    <Connector connectionTimeout="20000" port="8080" protocol="HTTP/1.1" redirectPort="8443"/>   
    <Connector port="8009" protocol="AJP/1.3" redirectPort="8443"/>

    <Engine defaultHost="localhost" name="Catalina">
      <Realm className="org.apache.catalina.realm.LockOutRealm">
        <Realm className="org.apache.catalina.realm.UserDatabaseRealm" resourceName="UserDatabase"/>
      </Realm>

      <Host appBase="webapps" autoDeploy="true" name="localhost" unpackWARs="true">
		  <Valve className="org.apache.catalina.valves.AccessLogValve" directory="logs" pattern="%h %l %u %t "%r" %s %b" prefix="localhost_access_log." suffix=".txt"/>

		  <Context docBase="D:\apache-tomcat-7.0.63\wtpwebapps\Cabinet_WS" path="/Cabinet_WS" reloadable="true" source="org.eclipse.jst.jee.server:Cabinet_WS"/>
	  </Host>

	  <!-- 加入新的虚拟主机 -->
       <Host appBase="mywebapps" autoDeploy="true" name="www.google.com" unpackWARs="true">
	  </Host>
    </Engine>
  </Service>
</Server>

三、Tomcat配置web应用 

3.1TomcatWeb应用的文件夹结构:

web应用文件夹结构假设文件夹结构不合法可能会出现各种问题.

news

|

|--静态资源和JSP文件都能够直接放置在web应用的文件夹下,浏览器能够直接訪问到

|--WEB-INF 

|--classes -- 动态web资源执行时的class文件要放在这个文件夹下

|--lib -- 动态web资源执行时所依赖的jar包要放在这个文件夹下

|--web.xml -- 整个web应用的配置文件,配置主页/Servlet的映射/过滤器监听器的配置都须要依赖这个文件进行

说明

WEB-INF -- 能够没有,可是最好有,假设有则一定要保证他的文件夹结构是完整的.放置在WEB-INF文件夹下的全部资源浏览器没有办法直接进行訪问

3.2Tomcat中配置web应用的几种方式:

方式一:这样的配置方式须要重新启动server不推荐

tomcat安装文件夹/conf/Server.xml的<Host>标签中,配置<Context>标签,就能够为该虚拟主机配置一个web应用了

缺省web应用设置:

假设将path设置为空则这个web应用为缺省web应用

演示样例代码例如以下:加粗部分

<?xml version="1.0" encoding="UTF-8"?>
<Server port="8005" shutdown="SHUTDOWN">
  <Listener className="org.apache.catalina.startup.VersionLoggerListener"/>  
  <Listener SSLEngine="on" className="org.apache.catalina.core.AprLifecycleListener"/>  
  <Listener className="org.apache.catalina.core.JasperListener"/>  
  <Listener className="org.apache.catalina.core.JreMemoryLeakPreventionListener"/>
  <Listener className="org.apache.catalina.mbeans.GlobalResourcesLifecycleListener"/>
  <Listener className="org.apache.catalina.core.ThreadLocalLeakPreventionListener"/>
 
  <GlobalNamingResources>
   
    <Resource auth="Container" description="User database that can be updated and saved" factory="org.apache.catalina.users.MemoryUserDatabaseFactory" name="UserDatabase" pathname="conf/tomcat-users.xml" type="org.apache.catalina.UserDatabase"/>
  </GlobalNamingResources>
  
  <Service name="Catalina">
    <Connector connectionTimeout="20000" port="8080" protocol="HTTP/1.1" redirectPort="8443"/>   
    <Connector port="8009" protocol="AJP/1.3" redirectPort="8443"/>

    <Engine defaultHost="localhost" name="Catalina">
      <Realm className="org.apache.catalina.realm.LockOutRealm">
        <Realm className="org.apache.catalina.realm.UserDatabaseRealm" resourceName="UserDatabase"/>
      </Realm>

      <Host appBase="webapps" autoDeploy="true" name="localhost" unpackWARs="true">
		  <Valve className="org.apache.catalina.valves.AccessLogValve" directory="logs" pattern="%h %l %u %t "%r" %s %b" prefix="localhost_access_log." suffix=".txt"/>
<!-- 加入新的web应用。应用名为HelloWord,虚拟路径/HelloWord -->
		  <Context docBase="D:\apache-tomcat-7.0.63\wtpwebapps\HelloWord" path="/HelloWord" reloadable="true" />
	  </Host>
    </Engine>
  </Service>
</Server>


</pre><pre>

当中<Context>标签属性说明: 

属性名

说明

path

訪问的URI,:http://localhost/是我的应用的根文件夹,在浏览器中訪问此应用将用。在地址栏输入:http://localhost/HelloWord

docBase

WEB应用的文件夹web application的文件存放的硬件路径或者是WAR文件存放硬件路径。

 

reloadable

是否在程序有修改时又一次加载,设置成true会影响性能,但可自己主动加载修改后的文件假设为true,则Tomcat将支持热部署,会自己主动检測web application/WEB-INF/lib/WEB-INF/classes文件夹的变化。自己主动装载新的JSPServlet,我们能够在不重起Tomcat的情况下改变web application

 

方式二、这样的配置方式不须要重新启动server,推荐使用

 

tomcat安装文件夹/conf/[EnginName]/[HostName]/在这个文件夹下写一个xml文件,当中xml文件的名字就是虚拟路径,在这个xml中能够配置<Context>标签,当中配置真实路径.

注意:

1)当中[EnginName]指的是在tomcat安装文件夹/conf/Server.xml这个配置文件里<Engin>标签元素相应的名字。

2[HostName]tomcat安装文件夹/conf/Server.xml这个配置文件里<Host>标签元素的名字。

3假设所配置的虚拟路径中有/。因为文件名称中不同意包括/须要用#替代.

 

使用方式二完毕方法一中同样的配置时,应进行例如以下操作:

1)在tomcat安装文件夹/conf/CataLina/localhost/文件夹下创建一个名为HelloWord.xml的文件,(若文件名称中有斜杠时使用#好取代:test#HelloWord.xml

2)在HelloWord.xml文件里写入例如以下代码:

<?

xml version="1.0" encoding="UTF-8"?> <Context docBase="D:\apache-tomcat-7.0.63\wtpwebapps\HelloWord" path="/HelloWord" reloadable="true" />

当中<Context>标签属性说明參照上面内容。

缺省web应用设置:

仅仅要将文件名称设置为ROOT.xml则这个xml描写叙述的web应用就成为了缺省web应用,

 

方式三、最简单、最经常使用的方式

直接将web应用放置到,虚拟主机管理的文件夹下,此时虚拟主机就会自己主动载入该文件夹下的web应用

 /conf/Server.xml<Host>标签中的属性appBase所指向的文件夹即为当前虚拟主机虚拟主机自己主动管理的文件夹,在属性autoDeploytrue的情况下。放置在这个文件夹下的web应用当前虚拟主机能够自己主动载入。

 

缺省web应用设置:

仅仅要将web应用目录名设置为ROOT则这个web应用就成为了缺省web应用。默认已经有一个web应用。即默认訪问的Tomcat的主页。


附关于/conf/Server.xml配置的具体说明


/conf/Server.xml文件的具体配置说明例如以下:

 <Server port="8005" shutdown="SHUTDOWN">  
 <!--属性说明  
    port:指定一个port,这个port负责监听关闭Tomcat的请求  
    shutdown:向以上port发送的关闭server的命令字符串  
 -->  
   <Listener className="org.apache.catalina.core.AprLifecycleListener" />  
   <Listener className="org.apache.catalina.mbeans.ServerLifecycleListener" />  
   <Listener className="org.apache.catalina.mbeans.GlobalResourcesLifecycleListener" />  
   <Listener className="org.apache.catalina.storeconfig.StoreConfigLifecycleListener"/>  
    
   <GlobalNamingResources>      
     <Environment name="simpleValue" type="java.lang.Integer" value="30"/>     
     <Resource name="UserDatabase" auth="Container"  
               type="org.apache.catalina.UserDatabase"  
        description="User database that can be updated and saved"  
            factory="org.apache.catalina.users.MemoryUserDatabaseFactory"  
           pathname="conf/tomcat-users.xml" />     
   </GlobalNamingResources>  
 
	<!-- 每一个Service元素仅仅能有一个Engine元素.元素处理在同一个<Service>中全部<Connector>元素接收到的客户请求   --> 
   <Service name="Catalina">  
	<!--属性说明  
     name:Service的名称  
	-->  

     <!--  
     Connector元素:由Connector接口定义.<Connector>元素代表与客户程序实际交互的给件,它负责接收客户请求,以及向客户返回响应结果.  
     -->  
    <Connector port="8080" protocol="HTTP/1.1"
               connectionTimeout="20000"
               redirectPort="8443" />
    <Connector port="8443" protocol="org.apache.coyote.http11.Http11Protocol"
               maxThreads="150" SSLEnabled="true" scheme="https" secure="true"
               clientAuth="false" sslProtocol="TLS" />
    <Connector port="8009" protocol="AJP/1.3" redirectPort="8443" />
     <!--属性说明  
     port:server连接器的port号,该连接器将在指定port侦听来自client的请求,设定Tcp/IPport,默认值为8080,假设把8080改成80,则仅仅要输入http://localhost就可以 由于TCP/IP的默认port是80 
     enableLookups:假设为true,则能够通过调用request.getRemoteHost()进行DNS查询来得到远程client的实际主机名;若为false则不进行DNS查询,而是返回其ip地址  
     redirectPort:server正在处理http请求时收到了一个SSL传输请求后重定向的port号  
     acceptCount:当全部能够使用的处理请求的线程都被用光时,能够放到处理队列中的请求数,超过这个数  的请求将不予处理,而返回Connection refused错误  
     connectionTimeout:等待超时的时间数(以毫秒为单位)  
     maxThreads:设定在监听port的线程的最大数目,这个值也决定了server能够同一时候响应客户请求的最大数目.默认值为200  
     protocol:必须设定为AJP/1.3协议.  
     address:假设server有两个以上IP地址,该属性能够设定port监听的IP地址,默认情况下,port会监听server上全部IP地址.  
     minProcessors:server启动时创建的处理请求的线程数,每一个请求由一个线程负责  
     maxProcessors:最多能够创建的处理请求的线程数  
     minSpareThreads:最小备用线程    
     maxSpareThreads:最大备用线程  
     debug:日志等级  
     disableUploadTimeout:禁用上传超时,主要用于大数据上传时  
     -->  
    
    
      
    
     <Engine name="Catalina" defaultHost="localhost">  
    <!--属性说明  
    name:相应$CATALINA_HOME/config/Catalina中的Catalina    
    defaultHost:相应Host元素中的name属性,也就是和$CATALINA_HOME/config/Catalina/localhost中的localhost缺省的处理请求的虚拟主机名,它至少与当中的一个Host元素的name属性值是一样的  
    debug:日志等级  --> 

       <Realm className="org.apache.catalina.realm.UserDatabaseRealm"  
              resourceName="UserDatabase"/>  
       
		<!--由Host接口定义.一个Engine元素能够包括多个<Host>元素.  每一个<Host>的元素定义了一个虚拟主机.它包括了一个或多个Web应用. -->
		<Host name="localhost" appBase="webapps"  
			unpackWARs="true" autoDeploy="true"  
			xmlValidation="false" xmlNamespaceAware="false">  
		<!--属性说明  
		name:在此例中一直被强调为$CATALINA_HOME/config/Catalina/localhost中的localhost 虚拟主机名  
        debug:是日志的调试等级    
        appBase:默认的应用路径,也就是把应用放在一个文件夹下,并在autoDeploy为true的情况下,放置在这个文件夹下的web应用当前虚拟主机能够自己主动载入
        unpackWARs:设置为true,在Web应用为*.war是,解压此WAR文件.假设为true,则tomcat会自己主动将WAR文件解压;否则不解压,直接从WAR文件里执行应用程序.  
        autoDeploy:默觉得true,表示假设有新的WEB应用放入appBase 而且Tomcat在执行的情况下,自己主动载入应用   -->  
     
			<Context path="/demm" docBase="E:\\projects\\demm\\WebRoot" debug="0" reloadable="true" >    
			</Context>  
			<!--属性说明  
			path:訪问的URI,如:http://localhost/是我的应用的根文件夹,訪问此应用将用:http://localhost/demm进行操作,
			docBase:WEB应用的文件夹.web application的文件存放的硬件路径或者是WAR文件存放硬件路径  
			debug:日志等级    
			reloadable:是否在程序有修改时又一次载入,设置成true会影响性能,但可自己主动载入修改后的文件.  
				假设为true。则Tomcat将支持热部署。会自己主动检測web application的/WEB-INF/lib    
				和/WEB-INF/classes文件夹的变化,自己主动装载新的JSP和Servlet,我们能够在不重起  
				Tomcat的情况下改变web application   --> 
       </Host>  
   
     </Engine>  
    
  </Service>  
</Server>   

<!--
标签的具体定义:
<Host>元素
属性:
	1>className:指定实现Host接口的类.默认值为StandardHost 
	2>appBase:指定虚拟主机的文件夹,能够指定绝对文件夹,也能够指定相对于的相对文件夹.假设没有此项,默觉得/webapps,此文件夹为虚拟主机管理的文件夹,放置在这个文件夹下的web应用当前虚拟主机能够自己主动载入
	3>autoDeploy:假设此项设为true,表示Tomcat服务处于执行状态时,能够监測appBase下的文件,假设有新有web应用增加进来,会自运公布这个WEB应用 
	4>unpackWARs:假设此项设置为true,表示把WEB应用的WAR文件先展开为开放文件夹结构后再执行.假设设为false将直接执行为WAR文件 
	5>alias:指定主机别名,能够指定多个别名 
	6>deployOnStartup:假设此项设为true,表示Tomcatserver启动时会自己主动公布appBase文件夹下全部的Web应用.假设Web应用中的server.xml没有相应的元素,将採用Tomcat默认的Context 
	7>name:定义虚拟主机的名字 
	
<Context> 元素:它由Context接口定义.是使用最频繁的元素.每一个能够包括多个元素.每一个web应用有唯一的一个相相应的Context代表web应用自身.servlet容器为第一个web应用创建一个 ServletContext对象
属性:
	1>className:指定实现Context的类,默觉得StandardContext类 
	2>path:指定訪问Web应用的URL入口,注意/myweb,而不是myweb了事 
	3>reloadable:假设这个属性设为true, Tomcat:server在执行状态下会监视在WEB-INF/classes和Web-INF/lib文件夹CLASS文件的改运.假设监视到有class文件被更新,server自又一次载入Web应用 
	3>cookies:指定是否通过Cookies来支持Session,默认值为true 
	4>useNaming:指定是否支持JNDI,默认值为了true
	
<Connector>元素
由Connector:接口定义.元素代表与客户程序实际交互的给件,它负责接收客户请求,以及向客户返回响应结果. 
第一个Connector:元素定义了一个HTTP Connector,它通过8080port接收HTTP请求;
第二个Connector:元素定义了一个JD Connector,它通过8009port接收由其他server转发过来的请求. 	
属性 
	1> className:指定实现Connector接口的类 
	2> enableLookups:假设设为true,表示支持域名解析,能够把IP地址解析为主机名.WEB应用中调用request.getRemoteHost方法返回客户机主机名.默认值为true 
	3> redirectPort:指定转发port.假设当前port仅仅支持non-SSL请求,在须要安全通信的场命,将把客户请求转发至SSL的redirectPortport 
HttpConnector元素的属性 
	1>className:实现Connector的类 
	2>port:设定Tcp/IPport,默认值为8080,假设把8080改成80,则仅仅要输入http://localhost就可以 由于TCP/IP的默认port是80 
	3>address:假设server有二个以上ip地址,此属性能够设定port监听的ip地址.默认情况下,port会监听server上全部的ip地址 
	4>bufferSize:设定由port创建的输入流的缓存大小.默认值为2048byte 
	5>protocol:设定Http协议,默认值为HTTP/1.1 
	6>maxThreads:设定在监听port的线程的最大数目,这个值也决定了server能够同一时候响应客户请求的最大数目.默认值为200 
	7>acceptCount:设定在监听port队列的最大客户请求数量,默认值为10.假设队列已满,客户必须等待. 
	8>connectionTimeout:定义建立客户连接超时的时间.假设为-1,表示不限制建立客户连接的时间 
-->



 

posted @ 2018-02-05 16:40  zhchoutai  阅读(253)  评论(0编辑  收藏  举报