Tomcat整体架构

一、Tomcat介绍

开源的java web应用服务器,实现了java EE的部分技术规范,如 java servlet、javaServer Pages、 JavaWebSocket等;

核心:http服务器+Servlet容器

二、Tomcat两个核心功能

1、处理Socket连接,负责网络字节流与Request和Response对象的转化

2、 加载和管理servlet,以及具体处理Request请求。

因此,Tomcat设计了两个核心组件,连接器(Connector)和容器(Container),连接器负责处理对外交流,容器负责内部处理;

三、核心组件

1、Server组件

整个Tomcat服务器,包含多组服务,负责管理和启动各个service,同事监听8005端口发来的shutdown命令,用于关闭整个容器;

2、 Service组件

每个Service组件都包含了若干个用于接收客户端的Connector组件和处理请求的Enigine组件。Service组件还包含了若干个Executor组件,每个Executor都是一个线程池,它可以为Service内所有组件提供线程池执行任务。

Tomcat为了实现多种IO模型和应用层协议,一个容器可能对接多个连接器,单独的连接器或者容器都不能对外提供服务,需要把他们组装起来才能工作,组装后的整体叫做Service组件;

Tomcat内可能有多个Service,这样的设计也是出于灵活性考虑。通过Tomcat中配置多个Service,可以实现通过不同的端口来访问同一台机器上部署的不同应用。

最顶层是Server(Tomcat实例),一个Server中有一个或多个Service,一个Server有多个连接器和一个容器;连接器和容器通过ServletRequest和ServletResponse通信;

3、连接器Connector组件

Tomcat 与外部世界的连接器,监听固定端口接收外部请求,传递给 Container,并将

Container 处理的结果返回给外部。

连接器对Servlet容器屏蔽了不同的应用层协议及IO模型,无论是HTTP还是AJp,容器中都是获取到一个标准的ServletRequest对象;

连接器功能:

a、监听网络端口

b、接收网络连接请求

c、读取请求字节流

d、根据具体协议解析字节流,生成统一对象

e、将Tomcat Request对象转换为ServletRequest对象

f、调用Servlet容器获得ServletResponse

g、将ServletResponse转换为Tomcat Response对象

h、将 Tomcat Response 转成网络字节流

将上述功能按照高内聚低耦合进行分析,可分为三个功能:

网络通信,应用层协议解析,Tomcat Request/Response 与 ServletRequest/ServletResponse 的转化;

按照上述拆分对应的三个功能,分别是EndPoint、Processor和Adapter:

EndPoint 负责提供字节流给 Processor;

Processor 负责提供 Tomcat Request 对象给 Adapter;

Adapter 负责提供 ServletRequest 对象给容器。

组件之间通过接口进行交互,变化与非变化部分隔离,增加复用性,降低耦合度;

Tomcat的设计者将网络通信和应用层协议解析放在一起,设计了ProtocolHandler接口;各种协议和通信模型的组合有响应的实现类;

Tomcat还设计了抽象基类来封装稳定的部分;抽象基类AbstractProtocol实现了ProtocolHandler接口;

4、ProtocolHandler组件

连接器用ProtocolHandler来处理网络协议和应用层协议,包含了两个重要部分:EndPoint和Processor;

Endpoint 负责调用底层socket通信,Proccessor负责应用层协议解析;

EndPoint 是一个接口,对应的抽象实现类是 AbstractEndpoint,而AbstractEndpoint 的具体子类,比如在 NioEndpoint 和 Nio2Endpoint 中,有两个重要的子组件:Acceptor 和 SocketProcessor。其中 Acceptor 用于监听 Socket 连接请求。SocketProcessor 用于处理接收到的 Socket 请求,它实现 Runnable 接口,在 Run 方法里调用协议处理组件 Processor 进行处理。为了提高处理能力,SocketProcessor 被提交到线程池来执行,而这个线程池叫作执行器(Executor)。

Processor 用来实现 HTTP/AJP 协议,Processor 接收来自 EndPoint 的 Socket,读取字节流解析成 Tomcat Request 和 Response 对象,并通过 Adapter 将其提交到容器处理,Processor 是对应用层协议的抽象。Processor 是一个接口,定义了请求的处理等方法。它的抽象实现类AbstractProcessor 对一些协议共有的属性进行封装,没有对方法进行实现。具体的实现有AJPProcessor、HTTP11Processor 等,这些具体实现类实现了特定协议的解析方法和请求处理方式。

EndPoint 接收到 Socket 连接后,生成一个 SocketProcessor 任务提交到线程池去处理,SocketProcessor 的 Run 方法会调用 Processor 组件去解析应用层协议,Processor通过解析生成 Request 对象后,会调用 Adapter 的 Service 方法。

5、Adapter组件

ProtocolHandler接口负责解析请求并生成Tomcat Request,Tomcat设计者引入CoyoteAdapter,这是适配器模式的经典运用;连接器调用CoyoteAdapter的Service方法传入Tomcat Request对象,CoyoteAdapter负责将对象转为ServletRequest,再调用容器中的Service方法;

相关推荐
皮皮林5511 小时前
IDEA 源码阅读利器,你居然还不会?
java·intellij idea
卡尔特斯5 小时前
Android Kotlin 项目代理配置【详细步骤(可选)】
android·java·kotlin
白鲸开源5 小时前
Ubuntu 22 下 DolphinScheduler 3.x 伪集群部署实录
java·ubuntu·开源
ytadpole5 小时前
Java 25 新特性 更简洁、更高效、更现代
java·后端
纪莫6 小时前
A公司一面:类加载的过程是怎么样的? 双亲委派的优点和缺点? 产生fullGC的情况有哪些? spring的动态代理有哪些?区别是什么? 如何排查CPU使用率过高?
java·java面试⑧股
JavaGuide7 小时前
JDK 25(长期支持版) 发布,新特性解读!
java·后端
用户3721574261357 小时前
Java 轻松批量替换 Word 文档文字内容
java
白鲸开源7 小时前
教你数分钟内创建并运行一个 DolphinScheduler Workflow!
java
Java中文社群7 小时前
有点意思!Java8后最有用新特性排行榜!
java·后端·面试
代码匠心7 小时前
从零开始学Flink:数据源
java·大数据·后端·flink