暂无图片
暂无图片
暂无图片
暂无图片
暂无图片

Tomcat系统结构与配置文件结构-1

孤岛鱼夫 2018-07-22
927

本公众号内容大多由平时操作整理记录,如果有错误的地方欢迎留言指正

tomcat安装

yum install java-1.7.0-openjdk.x86_64

yum install tomcat tomcat-admin-webapps tomcat-docs-webapp tomcat-webapps.noarch

tomcat的目录结构

bin:脚本,及启动时用到的类;
conf:配置文件目录;
lib:库文件,Java类库,jar;
logs:日志文件目录;
temp:临时文件目录;
webapps:web应用程序默认目录;
work:工作目录,存放编译后的字节码文件;

rpm包安装的程序环境

  • 配置文件目录:/etc/tomcat

  • 主配置文件:server.xml

  • webapps存放位置:/var/lib/tomcat/webapps/

  • examples  : 模板文件目录

  • manager : #应用程序管理器

  • ROOT : 站点程序存放路径

  • host-manager : 虚拟主机管理目录

  • docs : tomcat文件目录

  • Unit File:tomcat.service

  • 环境配置文件:/etc/sysconfig/tomcat

tomcat的配置文件构成

  • server.xml:主配置文件;

  • web.xml:每个webapp只有“部署”后才能被访问,它的部署方式通常由web.xml进行定义,其存放位置为WEB-INF/目录中;此文件为所有的webapps提供默认部署相关的配置;

  • context.xml:每个webapp都可以使用的配置文件,它通常由专用的配置文件context.xml来定义,其存放位置为WEB-INF/目录中;此文件为所有的webapps提供默认配置;

  • tomcat-users.xml:用户认证的账号和密码文件;角色(role),用户(User);此文件在tomcat启动时被装入内存;

  • catalina.policy:当使用-security选项启动tomcat时,用于为tomcat设置安全策略;

  • catalina.properties:Java属性的定义文件,用于设定类加载器路径,以及一些与JVM调优相关参数;

  • logging.properties:日志系统相关的配置;    

Tomcat组件结构


Connector负责接受客户的请求并向客户返回响应,在同一个Service中,多个Connector共享一个Engine。同一个Engine有多个Host,同一个Host有多个Context。

server组件

  • < Server port=”8005”shutdown=”SHUTDOWN” > :定义一个实例

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

Server的相关属性

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

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

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

Service组件

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

Service主要用于关联一个引擎和与此引擎相关的连接器(Connector),每个连接器通过一个特定的端口和协议接收入站请求交将其转发至关联的引擎进行处理。因此,Service要包含一个引擎、一个或多个连接器。

Service相关的属性

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

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

Connector组件(连接器)

进入Tomcat的请求可以根据Tomcat的工作模式分为如下两类:
Tomcat作为应用程序服务器:请求来自于前端的web服务器,这可能是Apache, IIS, Nginx等;
Tomcat作为独立服务器:请求来自于web浏览器;
一个连接器只对应一个引擎,但一个引擎可以有多个连接器。

定义连接器可以使用多种属性,有些属性也只适用于某特定的连接器类型。一般说来,常见于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所有处理线程均处于繁忙状态时,新发来的请求将被放置于等待队列中;

Engine组件

Engine是Servlet处理器的一个实例,即servlet引擎,默认为定义在server.xml中的Catalina。一个Engine元素中可以包含多个Host元素,每个Host元素定义了一个主机,它可以包含一个或者多个Web应用。

  • < Engine name="Catalina" defaultHost="localhost" >

常用的属性定义

defaultHost:Tomcat支持基于FQDN的虚拟主机,这些虚拟主机可以通过在Engine容器中定义多个不同的Host组件来实现;但如果此引擎的连接器收到一个发往非明确定义虚拟主机的请求时则需要将此请求发往一个默认的虚拟主机进行处理,因此,在Engine中定义的多个虚拟主机的主机名称中至少要有一个跟defaultHost定义的主机名称同名;
name:Engine组件的名称,用于日志和错误信息记录时区别不同的引擎;

Engine容器中可以包含Realm、Host、Listener和Valve子容器。

Host组件

Host组件位于Engine容器中用于接收请求并进行相应处理的主机或虚拟主机,如前面示例中的定义:

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

      </Host>

常用属性说明

  • name : 默认调用engine的defaultHost

  • appBase:此Host的webapps目录,即存放非归档的web应用程序的目录或归档后的WAR文件的目录路径;相当于DocumentRoot

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

  • unpackWars:是否自动展开war格式的归档文件;默认为true;

Context组件

Context是使用得最频繁的元素,每个Context元素代表了运行在虚拟机上的单个Web应用,一个Host元素中可以包含多个Context元素。

常用的属性定义有

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

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

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

Valve组件

valve组件是定义在host中的一个被嵌套组件,常用于嵌套在某一个虚拟主机的访问日志。

<Valve className="org.apache.catalina.valves.AccessLogValve" directory="logs"
               prefix="yufu123_access_log." suffix=".txt"
               pattern="%h %l %u %t "%r" %s %b" />

Valve存在多种类型

  • 定义访问日志:org.apache.catalina.valves.AccessLogValve

  • 定义访问控制:org.apache.catalina.valves.RemoteAddrValve

<Valve className="org.apache.catalina.valves.RemoteAddrValve" deny="172\.16\.100\.67"/>

定义属性

  • directoy:定义日志路径,默认是相对路径,连接至/var/log/tomcat下

  • prefix: 定义日志文件名的前缀

  • suffix : 定义日志文件名的后缀,中间名字为日期

  • pattern : 定义日志信息

总结上面的内容

  • Server代表整个Catalina Servlet容器,它是Tomcat的一个实例的顶层元素,其中可以包含一个或者多个Service元素。

  • Connector元素代表和客户程序实际交互的组件,它负责接受客户的请求,以及向客户返回响应结果。一个Connector元素只能对应一个service

  • Service元素中包含一个Engine元素,以及一个或者个多个Connector元素,这些Connector共享同一个Engine元素。每个Service元素只能包含一个Engine元素,Engine元素可以处理在同一个Service中所有Connector元素接受到的客户请求。

  • 一个Engine元素中可以包含多个Host元素,每个Host元素定义了一个主机,它可以包含一个或者多个Web应用。

  • Context是使用得最频繁的元素,每个Context元素代表了运行在虚拟机上的单个Web应用,一个Host元素中可以包含多个Context元素。

tomcat配置文件结构

tomcat配置文件结构与上面的结构相同,server.xml配置文件结构如下

Tomcat的核心组件:server.xml
            <Server>
                <Service>
                    <connector/>
                    <connector/>
                    ...
                    <Engine>
                        <Host>
                            <Context/>
                            <Context/>
                            ...
                        </Host>
                        <Host>
                            ...
                        </Host>
                        ...
                    </Engine>
                </Service>
            </Server>

每一个组件都由一个Java“类”实现,这些组件大体可分为以下几个类型

  • 顶级组件:Server ,代表一个运行的tomcat实例

  • 服务类组件:Service

  • 连接器组件:http, https, ajp(apache jserv protocol)

  • 容器类:Engine, Host, Context

  • 被嵌套类:valve, logger, realm, loader, manager

  • 集群类组件:listener, cluster, …










文章转载自孤岛鱼夫,如果涉嫌侵权,请发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。

评论