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连接器
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>
- 配置第一个Connector,客户端可以通过8080端口号协议访问tomcat。redirectPort强制要求https,而请求是http时,重定向至端口为8443的Connector。
- 第二个配置Connector,客户端可以通过8009端口使用AJP协议访问Tomcat。AJP协议负责和其他Http服务器(如Apache)建立连接;因为使用Apache处理静态资源速度快,Tomcat可以作为Servlet/JSP容器。
2.4 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