Tomcat系列之服务器的安装与配置以及各组件详解

大纲css

1、前言html

2、安装与配置Tomcat前端

3、Tomcat 目录的结构java

4、Tomcat 配置文件mysql

注,本文的测试的操做系统为CentOS 6.4 x86_64,软件版本为jdk-7u40、apache-tomcat-7.0.42。博文中的全部软件请到这里下载:http://yunpan.cn/QGBCLwrZnpLMSlinux


1、前言web

在上一篇博文中咱们主要讲解的Tomcat的基础知识以及相关的Java知识,对于不怎么清楚的博友能够参考一下:http://freeloda.blog.51cto.com/2033581/1298687。在这博客中咱们主要讲解Tomcat的安装与配置详解。那下面咱们就来讲一下吧!正则表达式

2、安装与配置Tomcatsql

1.查看一下安装文件数据库

[root@tomcat src]# ls
apache-tomcat-7.0.42.tar.gz jdk-7u40-linux-x64.rpm

2.同步一下时间

[root@tomcat java]# ntpdate 202.120.2.101

3.安装JDK

[root@tomcat src]# rpm -ivh jdk-7u40-linux-x64.rpm

4.修改环境变量

[root@tomcat tomcat]# cat /etc/profile.d/java.sh
export JAVA_HOME=/usr/java/jdk1.7.0_40 
export PATH=$PATH:$JAVA_HOME/bin

5.测试一下

[root@tomcat java]# java -version
java version "1.7.0_40" 
Java(TM) SE Runtime Environment (build 1.7.0_40-b43) 
Java HotSpot(TM) 64-Bit Server VM (build 24.0-b56, mixed mode)

注:好了,到这里咱们的jdk就安装成功了。下面咱们来安装一下Tomcat!

6.解压并建立连接

[root@tomcat src]# tar xf apache-tomcat-7.0.42.tar.gz -C /usr/local/
[root@tomcat local]# ln -sv apache-tomcat-7.0.42 tomcat

7.修改环境变量

[root@tomcat tomcat]# cat /etc/profile.d/tomcat.sh
export CATALINA_HOME=/usr/local/tomcat 
export PATH=$PATH:$CATALINA_HOME/bin

8.测试一下

[root@tomcat tomcat]# catalina.sh start
Using CATALINA_BASE:  /usr/local/tomcat 
Using CATALINA_HOME:  /usr/local/tomcat 
Using CATALINA_TMPDIR: /usr/local/tomcat/temp 
Using JRE_HOME:    /usr/java/jdk1.7.0_40 
Using CLASSPATH:    /usr/local/tomcat/bin/bootstrap.jar:/usr/local/tomcat/bin/tomcat-juli.jar

9.启动tomcat

[root@tomcat tomcat]# catalina.sh start
Using CATALINA_BASE:  /usr/local/tomcat 
Using CATALINA_HOME:  /usr/local/tomcat 
Using CATALINA_TMPDIR: /usr/local/tomcat/temp 
Using JRE_HOME:    /usr/java/jdk1.7.0_40 
Using CLASSPATH:    /usr/local/tomcat/bin/bootstrap.jar:/usr/local/tomcat/bin/tomcat-juli.jar

10.查看启动的端口

[root@tomcat tomcat]# netstat -ntulp
Active Internet connections (only servers) 
Proto Recv-Q Send-Q Local Address        Foreign Address       State    PID/Program name
tcp    0   0 0.0.0.0:22         0.0.0.0:*          LISTEN   1044/sshd    
tcp    0   0 127.0.0.1:25        0.0.0.0:*          LISTEN   1121/master   
tcp    0   0 127.0.0.1:6010       0.0.0.0:*          LISTEN   1155/sshd    
tcp    0   0 :::8080           :::*            LISTEN   1464/java    
tcp    0   0 :::22            :::*            LISTEN   1044/sshd    
tcp    0   0 ::1:25           :::*            LISTEN   1121/master   
tcp    0   0 ::1:6010          :::*            LISTEN   1155/sshd    
tcp    0   0 ::ffff:127.0.0.1:8005    :::*            LISTEN   1464/java    
tcp    0   0 :::8009           :::*            LISTEN   1464/java

11.测试访问一下

tomcat测试

注,好了到这里咱们的Tomcat就安装完成了,下面咱们就来看看咱们安装的内容。

3、Tomcat 目录的结构

1.Tomcat的安装

其实对于彻底由Java写成的Tomcat,Windows版本和Linux版本没有多大区别,好比Linux版本,在Solaris下也没有问题。这里,主要以Linux版本做为示例。

注,在安装使用Tomcat以前,先安装JDK,最好是Sun的JDK 1 .5 以上版。咱们上面已经安装过了,这里咱们就不在多说。

2.Tomcat的目录结构

首先,咱们先来简单查看一下目录文件,

[root@tomcat ~]# cd /usr/local/tomcat/
[root@tomcat tomcat]# ls 
bin conf lib LICENSE logs NOTICE RELEASE-NOTES RUNNING.txt temp webapps work

下面咱们来简单说明下,

  • bin ——Tomcat执行脚本目录

  • conf ——Tomcat配置文件

  • lib ——Tomcat运行须要的库文件(JARS)

  • logs ——Tomcat执行时的LOG文件

  • temp ——Tomcat临时文件存放目录

  • webapps ——Tomcat的主要Web发布目录(存放咱们本身的JSP,SERVLET,类)

  • work ——Tomcat的工做目录,Tomcat将翻译JSP文件到的Java文件和class文件放在这里。

下面咱们来讲一说各目录中包含的文件,

bin目录下的文件:

[root@tomcat tomcat]# ls bin/
bootstrap.jar    commons-daemon.jar      cpappend.bat setclasspath.bat startup.bat      tool-wrapper.bat 
catalina.bat    commons-daemon-native.tar.gz daemon.sh   setclasspath.sh  startup.sh      tool-wrapper.sh 
catalina.sh     configtest.bat        digest.bat  shutdown.bat   tomcat-juli.jar    version.bat 
catalina-tasks.xml configtest.sh         digest.sh   shutdown.sh    tomcat-native.tar.gz version.sh

咱们来讲说最主要主文件有,

  • catalina.sh 用于启动和关闭tomcat服务器

  • configtest.sh 用于检查配置文件

  • startup.sh 启动Tomcat脚本

  • shutdown.sh 关闭Tomcat脚本

conf目录下的文件:

[root@tomcat tomcat]# ls conf/
Catalina catalina.policy catalina.properties context.xml logging.properties server.xml tomcat-users.xml web.xml

最主要的配置文件有,

  • server.xml Tomcat 的全局配置文件

  • web.xml 为不一样的Tomcat配置的web应用设置缺省值的文件

  • tomcat-users.xml Tomcat用户认证的配置文件

lib目录下的文件:

[root@tomcat tomcat]# ls lib/
annotations-api.jar catalina-tribes.jar jasper.jar    tomcat-coyote.jar  tomcat-i18n-ja.jar 
catalina-ant.jar   ecj-4.2.2.jar    jsp-api.jar   tomcat-dbcp.jar   tomcat-jdbc.jar 
catalina-ha.jar   el-api.jar      servlet-api.jar tomcat-i18n-es.jar tomcat-util.jar 
catalina.jar     jasper-el.jar    tomcat-api.jar  tomcat-i18n-fr.jar

包含被Tomcat使用的各类各样的jar文件。在Linux/UNIX上,任何这个目录中的文件将被附加到Tomcat的classpath中。

logs目录下的文件:

[root@tomcat tomcat]# ls logs/
catalina.2013-09-18.log host-manager.2013-09-18.log localhost_access_log.2013-09-18.txt 
catalina.out       localhost.2013-09-18.log   manager.2013-09-18.log

主要的配置文件有,

  • localhost_access_log.2013-09-18.txt 访问日志

  • localhost.2013-09-18.log 错误和其它日志

  • manager.2013-09-18.log 管理日志

  • catalina.2013-09-18.log Tomcat启动或关闭日志文件

webapps目录下的文件:

[root@tomcat tomcat]# ls webapps/
docs examples host-manager manager ROOT

含Web应用的程序 (JSP、Servlet和JavaBean等)

work目录下的配置文件:

[root@tomcat tomcat]# ls work/
Catalina
[root@tomcat tomcat]# ls work/Catalina/localhost/
_/      docs/     examples/   host-manager/ manager/

由Tomcat自动生成,这是Tomcat放置它运行期间的中间(intermediate)文件(诸如编译的JSP文件)地方。 若是当Tomcat运行时,你删除了这个目录那么将不可以执行包含JSP的页面。

好了,Tomcat的目录结构咱们就说到这了,下面咱们来讲说Tomcat应用程序的组成。

3.Tomcat 应用程序的组成

注,上面的内容中咱们讲解了Tomcat的目录结构,其中有个目录是webapps,主要存放Web应用程序。那咱们下面来讲一说Web应用程序的组成。

按照Tomcat的规范,Tomcat的Web应用程序应该由以下目录组成,

(1).页面内容等文件的存放位置:*.html, *.jsp等能够有许多目录层次,由用户的网站结构而定,实现的功能应该是网站的界面,也就是用户主要的可见部分。除了HTML文件、JSP文件外,还有js(JavaScript)文件和css(样式表)文件以及其余多媒体文件等。

(2).Web-INF/web.xml 这是一个Web应用程序的描述文件。这个文件是一个XML文件,描述了Servlet和这个Web应用程序的其余组件信息,此外还包括一些初始化信息和安全约束等等。

(3).Web-INF/classes/ 这个目录及其下的子目录应该包括这个Web应用程序的全部JavaBean及Servlet等编译好的Java类文件(*.class)文件,以及没有被压缩打入JAR包的其余class文件和相关资源。注意,在这个目录下的Java类应该按照其所属的包层次组织目录(即若是该*.class文件具备包的定义,则该*.class文件应该放在.\WEB-INF\classes\包名下)。

(4).一般Web-INF/classes/ 这个目录下的类文件也能够打包成JAR文件,并能够放到WEB-INF下的lib目录下。如将 classes目录下的各个*.class文件打包成WebMis.jar文件(jar cvf WebMis.jar *.*)

注,

  • WEB-INF目录中包含应用软件所使用的资源,可是WEB-INF却不在公共文档根目录之中。在这个目录中所包含的文件都不能被客户机所访问。

  • 类目录中(在WEB-INF下)包含运行Web应用程序时所需的Servlets,Beans等类。

  • lib目录(在WEB-INF下)包含有Java archive files (JARs),例如标签库或者Servlets,Beans等类的*.jar文件。

  • 若是一个类出如今JAR文件中同时也出如今类的目录中,类加载器会加载位于类目录中的那一个。

(5). common/lib/ 这个目录下包含了全部压缩到JAR文件中的类文件和相关文件。好比:第三方提供的Java库文件、JDBC驱动程序等。

  • 其中msbase.jar、mssqlserver.jar、msutil.jar文件为SqlServer2000的JDBC驱动程序

  • 其中servlet-api.jar和jsp-api.jar为Servlet和JSP的API所在的包

好了,Tomcat的应用程序的能成咱们就基本说到这里了,下面咱们来看一下默认Web程序的目录结构。

[root@tomcat ~]# cd /usr/local/tomcat/
[root@tomcat tomcat]# ls 
bin conf lib LICENSE logs NOTICE RELEASE-NOTES RUNNING.txt temp webapps work 
[root@tomcat tomcat]# cd webapps/ 
[root@tomcat webapps]# ls 
docs examples host-manager manager ROOT 
[root@tomcat webapps]# cd examples/ 
[root@tomcat examples]# ls 
index.html jsp servlets WEB-INF websocket 
[root@tomcat examples]# cd WEB-INF/ 
[root@tomcat WEB-INF]# ls 
classes jsp jsp2 lib tags web.xml

到这里咱们的Tomcat的目录结构就讲解完成了,下面咱们得来详细说说,Tomcat的配置文件。

4、Tomcat 配置文件

1.简介

查看一下默认配置文件,

[root@tomcat ~]# cd /usr/local/tomcat/conf/
[root@tomcat conf]# ls
Catalina catalina.policy catalina.properties context.xml logging.properties server.xml tomcat-users.xml web.xml

Tomcat的配置文件默认存放在$CATALINA_HOME/conf目录中,主要有如下几个:

  • server.xml: Tomcat的主配置文件,包含Service, Connector, Engine, Realm, Valve, Hosts主组件的相关配置信息;

  • web.xml:遵循Servlet规范标准的配置文件,用于配置servlet,并为全部的Web应用程序提供包括MIME映射等默认配置信息;

  • tomcat-user.xml:Realm认证时用到的相关角色、用户和密码等信息;Tomcat自带的manager默认状况下会用到此文件;在Tomcat中添加/删除用户,为用户指定角色等将经过编辑此文件实现;

  • catalina.policy:Java相关的安全策略配置文件,在系统资源级别上提供访问控制的能力;

  • catalina.properties:Tomcat内部package的定义及访问相关的控制,也包括对经过类装载器装载的内容的控制;Tomcat在启动时会事先读取此文件的相关设置;

  • logging.properties: Tomcat经过本身内部实现的JAVA日志记录器来记录操做相关的日志,此文件即为日志记录器相关的配置信息,能够用来定义日志记录的组件级别以及日志文件的存在位置等;

  • context.xml:全部host的默认配置信息;

注,下面咱们对经常使用的配置文件进行详解。

2.server.xml

首先,咱们来查看一下默认的server.xml文件,

Tomcat以面向对象的方式运行,它能够在运行时动态加载配置文件中定义的对象结构,这有点相似于apache的httpd模块的调用方式。server.xml中定义的每一个主元素都会被建立为对象,并以某特定的层次结构将这些对象组织在一块儿。下面是默认配置,

[root@tomcat conf]# cat server.xml
<?xml version='1.0' encoding='utf-8'?> 
<!-- 
 Licensed to the Apache Software Foundation (ASF) under one or more 
 contributor license agreements. See the NOTICE file distributed with 
 this work for additional information regarding copyright ownership. 
 The ASF licenses this file to You under the Apache License, Version 2.0 
 (the "License"); you may not use this file except in compliance with 
 the License. You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
 Unless required by applicable law or agreed to in writing, software
 distributed under the License is distributed on an "AS IS" BASIS, 
 WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 
 See the License for the specific language governing permissions and 
 limitations under the License. 
--> 
<!-- Note: A "Server" is not itself a "Container", so you may not 
  define subcomponents such as "Valves" at this level. 
  Documentation at /docs/config/server.html 
--> 
<Server port="8005" shutdown="SHUTDOWN"> 
 <!-- Security listener. Documentation at /docs/config/listeners.html 
 <Listener className="org.apache.catalina.security.SecurityListener" /> 
 --> 
 <!--APR library loader. Documentation at /docs/apr.html --> 
 <Listener className="org.apache.catalina.core.AprLifecycleListener" SSLEngine="on" /> 
 <!--Initialize Jasper prior to webapps are loaded. Documentation at /docs/jasper-howto.html --> 
 <Listener className="org.apache.catalina.core.JasperListener" /> 
 <!-- Prevent memory leaks due to use of particular java/javax APIs--> 
 <Listener className="org.apache.catalina.core.JreMemoryLeakPreventionListener" /> 
 <Listener className="org.apache.catalina.mbeans.GlobalResourcesLifecycleListener" /> 
 <Listener className="org.apache.catalina.core.ThreadLocalLeakPreventionListener" />
 <!-- Global JNDI resources
  Documentation at /docs/jndi-resources-howto.html 
 --> 
 <GlobalNamingResources> 
 <!-- Editable user database that can also be used by 
   UserDatabaseRealm to authenticate users 
 --> 
 <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>
 <!-- A "Service" is a collection of one or more "Connectors" that share
  a single "Container" Note: A "Service" is not itself a "Container", 
  so you may not define subcomponents such as "Valves" at this level. 
  Documentation at /docs/config/service.html 
 --> 
 <Service name="Catalina">
 <!--The connectors can use a shared executor, you can define one or more named thread pools-->
 <!-- 
 <Executor name="tomcatThreadPool" namePrefix="catalina-exec-" 
  maxThreads="150" minSpareThreads="4"/> 
 -->
 <!-- A "Connector" represents an endpoint by which requests are received 
   and responses are returned. Documentation at : 
   Java HTTP Connector: /docs/config/http.html (blocking & non-blocking) 
   Java AJP Connector: /docs/config/ajp.html 
   APR (HTTP/AJP) Connector: /docs/apr.html 
   Define a non-SSL HTTP/1.1 Connector on port 8080 
 --> 
 <Connector port="8080" protocol="HTTP/1.1" 
    connectionTimeout="20000" 
    redirectPort="8443" /> 
 <!-- A "Connector" using the shared thread pool--> 
 <!-- 
 <Connector executor="tomcatThreadPool" 
    port="8080" protocol="HTTP/1.1" 
    connectionTimeout="20000" 
    redirectPort="8443" /> 
 --> 
 <!-- Define a SSL HTTP/1.1 Connector on port 8443 
   This connector uses the JSSE configuration, when using APR, the 
   connector should be using the OpenSSL style configuration 
   described in the APR documentation --> 
 <!-- 
 <Connector port="8443" protocol="HTTP/1.1" SSLEnabled="true" 
    maxThreads="150" scheme="https" secure="true" 
    clientAuth="false" sslProtocol="TLS" /> 
 -->
 <!-- Define an AJP 1.3 Connector on port 8009 -->
 <Connector port="8009" protocol="AJP/1.3" redirectPort="8443" />
 <!-- An Engine represents the entry point (within Catalina) that processes 
   every request. The Engine implementation for Tomcat stand alone 
   analyzes the HTTP headers included with the request, and passes them 
   on to the appropriate Host (virtual host). 
   Documentation at /docs/config/engine.html -->
 <!-- You should set jvmRoute to support load-balancing via AJP ie :
 <Engine name="Catalina" defaultHost="localhost" jvmRoute="jvm1"> 
 --> 
 <Engine name="Catalina" defaultHost="localhost">
  <!--For clustering, please take a look at documentation at:
   /docs/cluster-howto.html (simple how to) 
   /docs/config/cluster.html (reference documentation) --> 
  <!-- 
  <Cluster className="org.apache.catalina.ha.tcp.SimpleTcpCluster"/> 
  -->
  <!-- Use the LockOutRealm to prevent attempts to guess user passwords
   via a brute-force attack --> 
  <Realm className="org.apache.catalina.realm.LockOutRealm"> 
  <!-- This Realm uses the UserDatabase configured in the global JNDI 
    resources under the key "UserDatabase". Any edits 
    that are performed against this UserDatabase are immediately 
    available for use by the Realm. --> 
  <Realm className="org.apache.catalina.realm.UserDatabaseRealm" 
    resourceName="UserDatabase"/> 
  </Realm>
  <Host name="localhost" appBase="webapps"
   unpackWARs="true" autoDeploy="true">
  <!-- SingleSignOn valve, share authentication between web applications
    Documentation at: /docs/config/valve.html --> 
  <!-- 
  <Valve className="org.apache.catalina.authenticator.SingleSignOn" /> 
  -->
  <!-- Access log processes all example.
    Documentation at: /docs/config/valve.html 
    Note: The pattern used is equivalent to using pattern="common" --> 
  <Valve className="org.apache.catalina.valves.AccessLogValve" directory="logs" 
    prefix="localhost_access_log." suffix=".txt" 
    pattern="%h %l %u %t &quot;%r&quot; %s %b" />
  </Host>
 </Engine> 
 </Service> 
</Server>

注,看上去很复杂。其实,大部分都是注释。下面是一个简图说明了各组件之间的关系!

默认组件的关系

server.xml文件中可定义的元素很是多,包括Server, Service, Connector, Engine, Cluster, Host, Alias, Context, Realm, Valve, Manager, Listener, Resources, Resource, ResourceEnvRef, ResourceLink, WatchedResource, GlobalNameingResources, Store, Transaction, Channel, Membership, Transport, Member, ClusterListener等。

下面简单介绍几个经常使用组件:

(1).Server组件

如上面示例文件中定义的:

<Server port=”8005” shutdown=”SHUTDOWN”>

这会让Tomcat启动一个server实例(即一个JVM),它监听在8005端口以接收shutdown命令。各Server的定义不能使用同一个端口,这意味着若是在同一个物理机上启动了多个Server实例,必须配置它们使用不一样的端口。这个端口的定义用于为管理员提供一个关闭此实例的便捷途径,所以,管理员能够直接telnet至此端口使用SHUTDOWN命令关闭此实例。不过,基于安全角度的考虑,这一般不容许远程进行。

Server的相关属性:

  • className: 用于实现此Server容器的彻底限定类的名称,默认为org.apache.catalina.core.StandardServer;

  • port: 接收shutdown指令的端口,默认仅容许经过本机访问,默认为8005;

  • shutdown:发往此Server用于实现关闭tomcat实例的命令字符串,默认为SHUTDOWN;

(2).Service组件

Service主要用于关联一个引擎和与此引擎相关的链接器,每一个链接器经过一个特定的端口和协议接收入站请求交将其转发相当联的引擎进行处理。所以,Service要包含一个引擎、一个或多个链接器。

如上面示例中的定义:
<Service name=”Catalina”>

这定义了一个名为Catalina的Service,此名字也会在产生相关的日志信息时记录在日志文件当中。

Service相关的属性:

  • className: 用于实现service的类名,通常都是org.apache.catalina.core.StandardService。

  • name:此服务的名称,默认为Catalina;

(3).Connector组件

进入Tomcat的请求能够根据Tomcat的工做模式分为以下两类:

  • Tomcat做为应用程序服务器:请求来自于前端的web服务器,这多是Apache, IIS, Nginx等;

  • Tomcat做为独立服务器:请求来自于web浏览器;

Tomcat应该考虑工做情形并为相应情形下的请求分别定义好须要的链接器才能正确接收来自于客户端的请求。一个引擎能够有一个或多个链接器,以适应多种请求方式。

定义链接器可使用多种属性,有些属性也只适用于某特定的链接器类型。通常说来,常见于server.xml中的链接器类型一般有4种:

  • HTTP链接器

  • SSL链接器

  • AJP 1.3链接器

  • proxy链接器

如上面示例server.xml中定义的HTTP链接器:

<Connector port="8080" protocol="HTTP/1.1" 
  maxThreads="150" connectionTimeout="20000" 
  redirectPort="8443"/>

定义链接器时能够配置的属性很是多,但一般定义HTTP链接器时必须定义的属性只有“port”,定义AJP链接器时必须定义的属性只有"protocol",由于默认的协议为HTTP。如下为经常使用属性的说明:

  • address:指定链接器监听的地址,默认为全部地址,即0.0.0.0;

  • maxThreads:支持的最大并发链接数,默认为200;

  • port:监听的端口,默认为0;

  • protocol:链接器使用的协议,默认为HTTP/1.1,定义AJP协议时一般为AJP/1.3;

  • redirectPort:若是某链接器支持的协议是HTTP,当接收客户端发来的HTTPS请求时,则转发至此属性定义的端口;

  • connectionTimeout:等待客户端发送请求的超时时间,单位为毫秒,默认为60000,即1分钟;

  • enableLookups:是否经过request.getRemoteHost()进行DNS查询以获取客户端的主机名;默认为true;

  • acceptCount:设置等待队列的最大长度;一般在tomcat全部处理线程均处于繁忙状态时,新发来的请求将被放置于等待队列中;

下面是一个定义了多个属性的SSL链接器:

<Connector port="8443" 
 maxThreads="150" minSpareThreads="25" maxSpareThreads="75" 
 enableLookups="false" acceptCount="100" debug="0" scheme="https" secure="true" 
 clientAuth="false" sslProtocol="TLS" />

(4).Engine组件

Engine是Servlet处理器的一个实例,即servlet引擎,默认为定义在server.xml中的Catalina。Engine须要defaultHost属性来为其定义一个接收全部发往非明肯定义虚拟主机的请求的host组件。如前面示例中定义的:
<Engine name="Catalina" defaultHost="localhost">

经常使用的属性定义:

  • defaultHost:Tomcat支持基于FQDN的虚拟主机,这些虚拟主机能够经过在Engine容器中定义多个不一样的Host组件来实现;但若是此引擎的链接器收到一个发往非非明肯定义虚拟主机的请求时则须要将此请求发往一个默认的虚拟主机进行处理,所以,在Engine中定义的多个虚拟主机的主机名称中至少要有一个跟defaultHost定义的主机名称同名;

  • name:Engine组件的名称,用于日志和错误信息记录时区别不一样的引擎;

注,Engine容器中能够包含Realm、Host、Listener和Valve子容器。

(5).Host组件

位于Engine容器中用于接收请求并进行相应处理的主机或虚拟主机,如前面默认配置文件中定义:

<Host name="localhost" appBase="webapps" 
unpackWARs="true" autoDeploy="true" 
xmlValidation="false" xmlNamespaceAware="false"> 
</Host>

经常使用属性说明:

  • appBase:此Host的webapps目录,即存放非归档的web应用程序的目录或归档后的WAR文件的目录路径;可使用基于$CATALINA_HOME的相对路径;

  • autoDeploy:在Tomcat处于运行状态时放置于appBase目录中的应用程序文件是否自动进行deploy;默认为true;

  • unpackWars:在启用此webapps时是否对WAR格式的归档文件先进行展开;默认为true;

下面是虚拟主机定义示例:

<Engine name="Catalina" defaultHost="localhost">
 <Host name="localhost" appBase="webapps">
 <Context path="" docBase="ROOT"/>
 <Context path="/bbs" docBase="/web/bss"
  reloadable="true" crossContext="true"/>
 </Host>
 <Host name="mail.test.com" appBase="/web/mail">
 <Context path="" docBase="ROOT"/>
 </Host>
</Engine>

主机别名定义:

若是一个主机有两个或两个以上的主机名,额外的名称都可以以别名的形式进行定义,以下:

<Host name="www.test.com" appBase="webapps" unpackWARs="true">
 <Alias>test.com</Alias>
</Host>

(6).Context组件

Context在某些意义上相似于apache中的路径别名,一个Context定义用于标识tomcat实例中的一个Web应用程序;以下面的定义:

<!-- Tomcat Root Context -->
<Context path="" docBase="/web/webapps"/>
<!-- buzzin webapp -->
<Context path="/bbs"
 docBase="/web/threads/bbs"
 reloadable="true">
</Context>
<!-- chat server -->
 <Context path="/chat" docBase="/web/chat"/>
<!-- darian web -->
<Context path="/darian" docBase="darian"/>

在Tomcat中,每个context定义也可使用一个单独的XML文件进行,其文件的目录为$CATALINA_HOME/conf/<engine name>/<host name>。能够用于Context中的XML元素有Loader,Manager,Realm,Resources和WatchedResource。

经常使用的属性定义有:

  • docBase:相应的Web应用程序的存放位置;也可使用相对路径,起始路径为此Context所属Host中appBase定义的路径;切记,docBase的路径名不能与相应的Host中appBase中定义的路径名有包含关系,好比,若是appBase为deploy,而docBase毫不能为deploy-bbs类的名字;

  • path:相对于Web服务器根路径而言的URI;若是为空“”,则表示为此webapp的根路径;若是context定义在一个单独的xml文件中,此属性不须要定义;

  • reloadable:是否容许从新加载此context相关的Web应用程序的类;默认为false;

(7).Realm组件
一个Realm表示一个安全上下文,它是一个受权访问某个给定Context的用户列表和某用户所容许切换的角色相关定义的列表。所以,Realm就像是一个用户和组相关的数据库。定义Realm时唯一必需要提供的属性是classname,它是Realm的多个不一样实现,用于表示此Realm认证的用户及角色等认证信息的存放位置。

  • JAASRealm:基于Java Authintication and Authorization Service实现用户认证;

  • JDBCRealm:经过JDBC访问某关系型数据库表实现用户认证;

  • JNDIRealm:基于JNDI使用目录服务实现认证信息的获取;

  • MemoryRealm:查找tomcat-user.xml文件实现用户信息的获取;

  • UserDatabaseRealm:基于UserDatabase文件(一般是tomcat-user.xml)实现用户认证,它实现是一个彻底可更新和持久有效的MemoryRealm,所以可以跟标准的MemoryRealm兼容;它经过JNDI实现;

下面是一个常见的使用UserDatabase的配置:

<Realm className=”org.apache.catalina.realm.UserDatabaseRealm”
 resourceName=”UserDatabase”/>
下面是一个使用JDBC方式获取用户认证信息的配置:
 <Realm className="org.apache.catalina.realm.JDBCRealm" debug="99"
 driverName="org.gjt.mm.mysql.Driver"
 connectionURL="jdbc:mysql://localhost/authority"
 connectionName="test" connectionPassword="test"
 userTable="users" userNameCol="user_name"
 userCredCol="user_pass"
 userRoleTable="user_roles" roleNameCol="role_name" />

(8).Valve组件

Valve相似于过滤器,它能够工做于Engine和Host/Context之间、Host和Context之间以及Context和Web应用程序的某资源之间。一个容器内能够创建多个Valve,并且Valve定义的次序也决定了它们生效的次序。Tomcat中实现了多种不一样的Valve:

  • AccessLogValve:访问日志Valve

  • ExtendedAccessValve:扩展功能的访问日志Valve

  • JDBCAccessLogValve:经过JDBC将访问日志信息发送到数据库中;

  • RequestDumperValve:请求转储Valve;

  • RemoteAddrValve:基于远程地址的访问控制;

  • RemoteHostValve:基于远程主机名称的访问控制;

  • SemaphoreValve:用于控制Tomcat主机上任何容器上的并发访问数量;

  • JvmRouteBinderValve:在配置多个Tomcat为以Apache经过mod_proxy或mod_jk做为前端的集群架构中,当指望中止某节点时,能够经过此Valve将用记请求定向至备用节点;使用此Valve,必须使用JvmRouteSessionIDBinderListener;

  • ReplicationValve:专用于Tomcat集群架构中,能够在某个请求的session信息发生更改时触发session数据在各节点间进行复制;

  • SingleSignOn:将两个或多个须要对用户进行认证webapp在认证用户时链接在一块儿,即一次认证便可访问全部链接在一块儿的webapp;

  • ClusterSingleSingOn:对SingleSignOn的扩展,专用于Tomcat集群当中,须要结合ClusterSingleSignOnListener进行工做;

RemoteHostValve和RemoteAddrValve能够分别用来实现基于主机名称和基于IP地址的访问控制,控制自己能够经过allow或deny来进行定义,这有点相似于Apache的访问控制功能;以下面的Valve则实现了仅容许本机访问/probe:

<Context path="/probe" docBase="probe">
<Valve className="org.apache.catalina.valves.RemoteAddrValve"
allow="127\.0\.0\.1"/>
</Context>

其中相关属性定义有:

  • className:相关的java实现的类名,相应于分别应该为org.apache.catalina.valves.RemoteHostValve或org.apache.catalina.valves.RemoteAddrValve;

  • allow:以逗号分开的容许访问的IP地址列表,支持正则表达式,所以,点号“.”用于IP地址时须要转义;仅定义allow项时,非明确allow的地址均被deny;

  • deny: 以逗号分开的禁止访问的IP地址列表,支持正则表达式;使用方式同allow;

(9).GlobalNamingResources

应用于整个服务器的JNDI映射,此能够避免每一个Web应用程序都须要在各自的web.xml建立,这在web应用程序以WAR的形式存在时尤其有用。它一般能够包含三个子元素:

  • Environment;

  • Resource;

  • ResourceEnvRef;

(10).WatchedResource

WatchedResource能够用于Context中监视指定的webapp程序文件的改变,而且可以在监视到文件内容发生改变时从新装载此文件。

(11).Listener

Listener用于建立和配置LifecycleListener对象,而LifecycleListener一般被开发人员用来建立和删除容器。

(12).Loader

Java的动态装载功能是其语言功能强大表现之一,Servlet容器使用此功能在运行时动态装载servlet和它们所依赖的类。Loader能够用于Context中控制java类的加载。

(13).Manager

Manger对象用于实现HTTP会话管理的功能,Tomcat中有5种Manger的实现:

1) StandardManager

Tomcat的默认会话管理器,用于非集群环境中对单个处于运行状态的Tomcat实例会话进行管理。当Tomcat关闭时,这些会话相关的数据会被写入磁盘上的一个名叫SESSION.ser的文件,并在Tomcat下次启动时读取此文件。

2) PersistentManager

当一个会话长时间处于空闲状态时会被写入到swap会话对象,这对于内存资源比较吃紧的应用环境来讲比较有用。

3)DeltaManager

用于Tomcat集群的会话管理器,它经过将改变了会话数据同步给集群中的其它节点实现会话复制。这种实现会将全部会话的改变同步给集群中的每个节点,也是在集群环境中用得最多的一种实现方式。

4) BackupManager

用于Tomcat集群的会话管理器,与DeltaManager不一样的是,某节点会话的改变只会同步给集群中的另外一个而非全部节点。

5)SimpleTcpReplicationManager

Tomcat4时用到的版本,过于老旧了。

(14).Stores

PersistentManager必须包含一个Store元素以指定将会话数据存储至何处。这一般有两种实现方式:FileStore和JDBCStore。

(15).Resources

常常用于实如今Context中指定须要装载的但不在Tomcat本地磁盘上的应用资源,如Java类,HTML页面,JSP文件等。

(16).Cluster

专用于配置Tomcat集群的元素,可用于Engine和Host容器中。在用于Engine容器中时,Engine中的全部Host均支持集群功能。在Cluster元素中,须要直接定义一个Manager元素,这个Manager元素有一个其值为org.apache.catalina.ha.session.DeltaManager或org.apache.catalina.ha.session.BackupManager的className属性。同时,Cluster中还须要分别定义一个Channel和ClusterListener元素。

  • Channel 用于Cluster中给集群中同一组中的节点定义通讯“信道”。Channel中须要至少定义Membership、Receiver和Sender三个元素,此外还有一个可选元素Interceptor。

  • Membership 用于Channel中配置同一通讯信道上节点集群组中的成员状况,即监控加入当前集群组中的节点并在各节点间传递心跳信息,并且能够在接收不到某成员的心跳信息时将其从集群节点中移除。Tomcat中Membership的实现是org.apache.catalina.tribes.membership.McastService。

  • Sender 用于Channel中配置“复制信息”的发送器,实现发送须要同步给其它节点的数据至集群中的其它节点。发送器不须要属性的定义,但能够在其内部定义一个Transport元素。

  • Transport 用于Sender内部,配置数据如何发送至集群中的其它节点。Tomcat有两种Transport的实现:
    1) PooledMultiSender
    基于Java阻塞式IO,能够将一次将多个信息并发发送至其它节点,但一次只能传送给一个节点。
    2)PooledParallelSener
    基于Java非阻塞式IO,即NIO,能够一次发送多个信息至一个或多个节点。

  • Receiver 用于Channel定义某节点如何从其它节点的Sender接收复制数据,Tomcat中实现的接收方式有两种BioReceiver和NioReceiver。

3.web.xml

web.xml基于Java Servlet规范,可被用于每个Java servlet容器,一般有两个存放位置,$CATALINA_BASE/conf和每一个Web应用程序(一般是WEB-INF/web.xml)。Tomcat在deploy一个应用程序时(包括重启或从新载入),它首先读取conf/web.xml,然后读取WEB-INF/web.xml。

好了,到这里Tomcat服务器的安装与配置以及各组件详解就说到这里了,但愿你们有所收获^_^…… 在前面的两篇博客中咱们主要讲解了,Tomcat相关的理论知识与相关组件的讲解,从下一篇博客开始,咱们将讲解Tomcat的相关操做,包括Nginx结合Tomcat、Apache结合Tomcat、Tomcat集群讲解等。