文章目录


Tomcat - Tomcat的套娃式架构设计初探_servlet


Tomcat的主要功能

Tomcat - Tomcat的套娃式架构设计初探_服务器_02

核心功能: http服务器和servlet 容器

  • Http服务器功能 : Socket通信(TCP/IP)、解析HTTP报文

  • Servlet容器功能 : 实现了Servlet规范 , 有多个Servlet(自带Servlet + 自定义Servlet),Servlet处理具体的业务


Tomcat的架构初探

刚才说了tomcat核心功能有两个 : http服务器和Servlet 容器。 那tomcat为了实现如上两个核心功能又是怎样架构的呢?

为了实现上面的功能,tomcat封装出了很多组件 ,这些组件共同组成了Tomcat的架构。

Tomcat - Tomcat的套娃式架构设计初探_虚拟主机_03

进一步分析一下

我们既然说了tomcat的两个核心功能,HTTP和Servlet , 具体在架构中对应的部分是哪些呢?

HTTP------> Connector

Servlet --------> Container


Connector 组件 -Coyote

Connector 组件 在tomcat中,有个专门的名称,叫 Coyote ,专门处理HTTP服务器功能

Coyote的组成

我们把Connector组件放大来看一下

Tomcat - Tomcat的套娃式架构设计初探_架构设计_04

  • EndPoint 组件进行Socket通信,处理TCP请求

  • Processor 组件解析HTTP报文,处理HTTP请求

这两个组件被称为 ProtocolHandler

HTTP请求 都是处理的Request, 而 Catalina 实现了Servlet规范,主要处理的是ServletRequest请求,所以这俩没法直接交互,因此才有了Adapter 组件,用来转换Request 和 ServletRequest

顺便说一下 AJP,这个是早期tomcat为了继承Apache的静态资源服务 的时候使用的协议,(Tomcat更擅长处理动态资源)


Container 组件 -Catalina

Container 组件的主要功能是完成Servlet容器功能, 也有个专门的名称叫 Catalina

Catalina 的组成

Tomcat - Tomcat的套娃式架构设计初探_虚拟主机_05

  • Engine&Host: Engine组件(引擎) 是Servlet容器Catalina的核心,它支持在其下定义多个虚拟主机(Host) , 虚拟主机允许Tomcat引擎在将配置在一天主机上的多个域名(比如www.artisan.com , www.art.com) 分割开来互不干扰

  • Context: 每个虚拟主机又可以支持多个web应用部署在它下边,这就是我们常说的上下文Context对象. 上下文使用由Servlet规范中指定的Web应用程序格式表示,不论是压缩过的war包还是未压缩的目录形式

  • Wrapper: 在上下文中又可以部署多个Servlet ,并且每个Servlet都会被一个包装组件(Wrapper)所包含 (一个wrapper对应一个Servlet)


server-service-connector/container-engine-host-context-wrapper

除了Connector组件和Container组件,Tomcat其实还定义了很多组件来工作

(server-service-connector/container-engine-host-context-wrapper)

这些组件采用一层一层的设计方式(套娃式) 。 如果一个组件包含了其他组件,那么这个组件也称之为容器。

瞅一瞅俄罗斯套娃 哈哈

Tomcat - Tomcat的套娃式架构设计初探_servlet_06


总体架构预览

说了这多,汇总如下Tomcat - Tomcat的套娃式架构设计初探_虚拟主机_07