Tomcat(一)系统架构

2 篇文章 0 订阅
1 篇文章 0 订阅

一、Tomcat系统架构

Tomcat系统架构图

  • Server:Tomcat顶层容器,可以包含一个或者多个Service组件
  • Service:包含Connector 和Container 两个核心组件。
  • Connector:连接器,用于处理连接相关的事情,并提供Socket于Request、Response相关的转化
  • Container:容器,用于封装和管理Servlet,以及具体处理Request请求

二、Tomcat配置说明

<?xml version="1.0" encoding="UTF-8"?>
<Server port="8005" shutdown="SHUTDOWN">
  <Listener className="org.apache.catalina.startup.VersionLoggerListener" />
  <Listener className="org.apache.catalina.core.AprLifecycleListener" SSLEngine="on" />
  <Listener className="org.apache.catalina.core.JreMemoryLeakPreventionListener" />
  <Listener className="org.apache.catalina.mbeans.GlobalResourcesLifecycleListener" />
  <Listener className="org.apache.catalina.core.ThreadLocalLeakPreventionListener" />
 
  <GlobalNamingResources>
    <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 name="Catalina">
    <Connector port="8080" protocol="HTTP/1.1"
               connectionTimeout="20000"
               redirectPort="8443" />
    <Engine name="Catalina" defaultHost="localhost">
      <Realm className="org.apache.catalina.realm.LockOutRealm">
        <Realm className="org.apache.catalina.realm.UserDatabaseRealm"
               resourceName="UserDatabase"/>
      </Realm>
 
      <Host name="localhost"  appBase="webapps"
            unpackWARs="true" autoDeploy="true">
        <Valve className="org.apache.catalina.valves.AccessLogValve" directory="logs"
               prefix="localhost_access_log" suffix=".txt"
               pattern="%h %l %u %t "%r" %s %b" />
      </Host>
      
    </Engine>
  </Service>
</Server>

2.1 Server

2.1.1 简介

声明一个服务器,提供了一种优雅的方式来启动和停止整个系统,不必单独启停连接器和容器

2.1.2 属性

  • port:表示Server 接收shutdown指令的端口,设置-1可以禁掉该端口
  • shutdown:关闭Server的指令

2.2 Service

2.2.1 简介

一个服务组件包含一个引擎Engine与此引擎相关联的一个或多个连接器Connector。给服务命名可以在日志文件中识别不同服务产生的日志。

2.2.2 属性

  • name:服务器名称,默认Catalina
  • className:用于实现service的类名,一般都是StandardService

2.2.3 其他组件

  • Manager:管理器,用于管理会话Session
  • Logger:日志器,用于管理日志
  • Loader:加载器,和类加载有关,只会开放给Context使用
  • Pipeline:管道组件,配合Valve实现过滤器功能
  • Valve:阀门组件,配合Pipeline实现过滤器功能
  • Realm:认证授权组件

2.3 Connector连接器

Connector架构图

2.3.1 简介

  • Connector就是使用ProtocolHandler来处理请求的,不同的ProtocolHandler代表不同的连接类型,比如:Http11Protocol使用的是普通Socket来连接的,Http11NioProtocol使用的是NioSocket来连接的。ProtocolHandler由包含了三个部件:Endpoint、Processor、Adapter。
  • Endpoint用来处理底层Socket的网络连接,Processor用于将Endpoint接收到的Socket封装成Request,Adapter用于将Request交给Container进行具体的处理。
  • Endpoint由于是处理底层的Socket网络连接,因此Endpoint是用来实现TCP/IP协议的,而Processor用来封装Http Request和Response,所以必须实现HTTP协议,Adapter将请求适配到Servlet容器进行具体的处理。
  • Endpoint的抽象实现AbstractEndpoint里面定义的Acceptor和AsyncTimeout两个内部类和一个Handler接口。Acceptor用于监听请求,AsyncTimeout用于检查异步Request的超时,Handler用于处理接收到的Socket,在内部调用Processor进行处理。
  • 连接器,接收连接请求,创建Request、Response对象用于和请求端交互数据;然后分配线程让Engine来处理请求。

2.3.2 常见连接器种类

1. HTTP连接器
2. SSL连接器
3. AJP 1.3连接器
4. proxy连接器

2.3.3 属性

通常定义HTTP连接器时必须定义属性只有port,定义AJP连接器时必须定义属性只有protocol。

  • address:指定连接器监听的地址,默认所有地址,即0.0.0.0;
  • maxThreads:支持最大的并发连接数,默认200
  • port:监听的端口,默认为0
  • protocol:连接器使用的协议,默认为HTTP/1.1,定义AJP协议通常为AJP/1.3
  • redirectPort:当接受客户端的HTTPS请求时,则转发至此属性定义的端口
  • connectionTimeout:等待客户端发送请求的超时时间,单位为毫秒,默认60000,即1分钟
  • enableLookups:true,则可以通过request.getRemoteHost()进行DNS查询获取远程客户端的实际主机名;false,则返回其ip地址。
  • acceptCount:设置等待队列的最大长度,即所有可以使用的处理请求的线程都被用光了,可将请求放到队列中的请求数。超过此数值返回Connection wan refused错误。
  • minProcessors:服务器启动时创建的最小线程数
  • maxProcessors:最大创建处理请求的线程数
  • minSpareThreads:最小备用线程
  • maxSpareThreads:最大备用线程
  • disableUploadTimeout:禁止上传超时,主要用于大数据上传时

2.3.4 Tomcat与Apache整合

<Service name="Catalina"> 
  <Connector connectionTimeout="20000" port="8080" protocol="HTTP/1.1" redirectPort="8443"/>  
  <Connector port="8009" protocol="AJP/1.3" redirectPort="8443"/>  
  <Connector port="8099" protocol="HTTP/1.1" maxThreads="150" minSpareThreads="25" maxSpareThreads="75" enableLookups="false" redirectPort="8443" acceptCount="100" debug="0" connectionTimeout="20000" URIEncoding="utf-8" disableUploadTimeout="true"/>  
</Service>
  1. 配置第一个Connector,客户端可以通过8080端口号协议访问tomcat。redirectPort强制要求https,而请求是http时,重定向至端口为8443的Connector。
  2. 第二个配置Connector,客户端可以通过8009端口使用AJP协议访问Tomcat。AJP协议负责和其他Http服务器(如Apache)建立连接;因为使用Apache处理静态资源速度快,Tomcat可以作为Servlet/JSP容器。

2.4 Container容器

Container容器架构图

2.4.1 简介

Container处理请求是使用Pipeline-Valve(管道-阀门)来处理的。
每个Pipeline都有一个特殊的Valve,该Valve在管道最后一个执行,这个Valve叫做BaseValve,BaseValve是不可删除的,上层容器的管道的BaseValve中会调用下层容器的管道
Container中包含四个子容器,而这四个子容器对应的BaseValve分别为:StandardEngineValve、StandardHostValve、StandardContextValve、StandardWrapperValve。

2.5 Engine引擎

2.5.1 简介

是Service组件中的请求处理组件。从一个或者多个Connector中接受并处理,完成响应返回给Connector。

2.5.2 属性

<Engine defaultHost="localhost" name="Catalina"></Engine>
  • name:用于日志和错误信息记录时区分不同的引擎
  • defalurHost:指定默认的Host名称,必须与一个Host组件的name匹配。当请求的host名称不存在时,使用制定默认的host进行处理。

2.6 Host虚拟主机

2.6.1 简介

代表虚拟主机。对应服务器中一个网络名实体(如“www.test.com”或IP地址“116.25.25.25”);网络名应该在DNS服务器上注册。

2.6.2 属性

  <Engine defaultHost="localhost" name="Catalina"> 
    <Realm className="org.apache.catalina.realm.UserDatabaseRealm" resourceName="UserDatabase"/>  
    <Host appBase="webapps" autoDeploy="true" name="localhost" unpackWARs="true" xmlNamespaceAware="false" xmlValidation="false"></Host> 
  </Engine> 
  • name:虚拟主机名
  • appBase:此Host的webapps目录,即存放war文件的目录路径。可以使用基于$CATALINA_HOME的相对路径
  • autoDeploy:Tomcat运行状态时,appBase目录有新的web应用存放,是否进行自动载入此应用,默认为true
  • unpackWats:在启动webapps时,是否对WAR格式文件进行解压,默认true
    Alias标签一个主机有两个以上的主机名,额外的名称可以已别名的形式进行定义

2.7 Context

2.7.1 简介

表示Web应用程序本身,最主要指定Web应用程序的根目录。若自动部署(autoDeploy=“true”),那么server.xml中没有Context元素的配置。

2.7.2 属性

<Host appBase="webapps" autoDeploy="true" name="www.lidol.top" unpackWARs="true">
    <!--访问路径:www.lidol.top/demo1-->
    <Context docBase="/Users/zhuoli/Documents/demo/demo1" path="/demo1" reloadable="true"/> 
    <!--访问路径:www.lidol.top/demo2-->
    <Context docBase="/Users/zhuoli/Documents/demo/demo2" path="/demo2" reloadable="true"/> 
</Host>  
  • docBase:Web应用(WAR)存放位置,起始路径为Host中appBase定义路径。
  • path:相对于Web服务器根路径而言的URI。形式为http://localhost:8080/path/*
  • reloadable:是否允许重新加载Web应用程的类。WEB-INF/lib和WEB-INF/classes
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

weixin_42242792

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值