简述Tomcat体系结构
Tomcat请求处理流程
流程大致说明:
- 用户请求至Tomcat服务器,Tomcat将其封装为ServletRequest对象。
- Servlet容器初始化时会初始化部署在tomcat下业务类,放入Servlet容器中(用户请求前,tomcat启动时)。
- 第1步执行完后会使用ServletRequest对象中的信息(url,请求方式)等去Servlet容器中寻找对应的Servlet。
- 如果Servlet还没有被加载,就⽤反射机制创建这个Servlet,并调⽤Servlet的init⽅法来完成初始化。
- 调用Servlet的service方法处理请求。
- 将请求结果封装为ServletResponse,并返回给http服务器。
- HTTP服务器会把响应发送给客户端。
Tomcat核心组件
Tomcat拥有两个核心组件:连接器(Connector)和容器(Container)
组件 | 说明 |
---|---|
连接器 | 负责对外交流: 处理Socket连接,负责⽹络字节流与Request和Response对象的转化; |
容器 | 加载和管理Servlet,以及具体处理Request请求; |
Coyote 连接器
Coyote 负责将客户端发送过来的Socket请求封装为ServletRequest与将Container处理结果封装ServletResponse对象。大体流程如下图:
组件 | 作⽤描述 |
---|---|
EndPoint | EndPoint 是 Coyote 通信端点,即通信监听的接⼝,是具体Socket接收和发送处理器,是对传输层的抽象,因此EndPoint⽤来实现TCP/IP协议的 |
Processor | Processor 是Coyote 协议处理接⼝ ,如果说EndPoint是⽤来实现TCP/IP协议的,那么Processor⽤来实现HTTP协议,Processor接收来⾃EndPoint的Socket,读取字节流解析成Tomcat Request和Response对象,并通过Adapter将其提交到容器处理,Processor是对应⽤层协议的抽象 |
ProtocolHandler | Coyote 协议接⼝, 通过Endpoint 和 Processor , 实现针对具体协议的处理能⼒。Tomcat 按照协议和I/O 提供了6个实现类 : AjpNioProtocol ,AjpAprProtocol, AjpNio2Protocol , Http11NioProtocol ,Http11Nio2Protocol ,Http11AprProtocol |
Adapter | 由于协议不同,客户端发过来的请求信息也不尽相同,Tomcat定义了⾃⼰的Request类来封装这些请求信息。ProtocolHandler接⼝负责解析请求并⽣成Tomcat Request类。但是这个Request对象不是标准的ServletRequest,不能⽤Tomcat Request作为参数来调⽤容器。Tomcat设计者的解决⽅案是引⼊CoyoteAdapter,这是适配器模式的经典运⽤,连接器调⽤CoyoteAdapter的Sevice⽅法,传⼊的是Tomcat Request对象,CoyoteAdapter负责将Tomcat Request转成ServletRequest,再调⽤容器 |
Catalina 容器
- Tomcat是一个由一系列可配置(conf/server.xml)组件组成的Web容器,Catalina就是Tomcat的Servlet容器。
- 因为Catalina是Tomcat的核心,所以可以简单理解为Tomcat就是一款Servlet容器,比如 Coyote 模块提供链接通信,Jasper 模块提供 JSP 引擎,Naming 提供JNDI 服务,Juli 提供⽇志服务等都是由Catalina提供支撑的。
其中Catalina与其它实例的关系为:
实例 | 用途 |
---|---|
Catalina | 负责解析Tomcat的配置⽂件(server.xml) , 以此来创建服务器Server组件并进⾏管理 |
Server | 服务器表示整个Catalina Servlet容器以及其它组件,负责组装并启动Servlaet引擎,Tomcat连接器。Server通过实现Lifecycle接⼝,提供了⼀种优雅的启动和关闭整个系统的⽅式 |
Service | 服务是Server内部的组件,⼀个Server包含多个Service。它将若⼲个Connector组件绑定到⼀个Container |
Container | 容器,负责处理⽤户的servlet请求,并返回对象给web⽤户的模块 |
Container 组件具体结构
实例 | 用途 |
---|---|
Engine | 表示整个Catalina的Servlet引擎,⽤来管理多个虚拟站点,⼀个Service最多只能有⼀个Engine,但是⼀个引擎可包含多个Host |
Host | 代表⼀个虚拟主机,或者说⼀个站点,可以给Tomcat配置多个虚拟主机地址,⽽⼀个虚拟主机下可包含多个Context |
Context | 表示⼀个Web应⽤程序, ⼀个Web应⽤可包含多个Wrapper |
Wrapper | 表示⼀个Servlet,Wrapper 作为容器中的最底层,不能包含⼦容器 |