首页 > 其他分享 >Tomcat总体架构,启动流程与处理请求流程

Tomcat总体架构,启动流程与处理请求流程

时间:2023-05-07 22:14:03浏览次数:46  
标签:架构 请求 Tomcat 处理 流程 Server Connector 组件

系列文章目录和关于我

参考书籍《Tomcat架构解析》

一丶Tomcat总体架构

本文沿袭《Tomcat架构解析》中启发式的方式来总结Tomcat总体架构

1 Server

假设当前我们要编写一个web应用服务器,web应用服务器最基本的功能是接受客户端发送的请求数据并进行解析,完成相关的业务处理,然后将处理结果作为响应返回给请求计算机,于是我们定义了下面Server类

image-20230507180211525

从上面这段话来看,如果我们将上述功能全部让Server去做实现,那么让请求监听和请求处理耦合度很高,不利于扩展,比如监听方式发生变化(比如之前使用BIO,现在使用NIO),或者请求处理方式改变(之前遵循Servlet规范,请求交给Servlet对象处理,现在适配另外一种规范)这种变化会导致我们在Server对象中修改代码,不满足开闭原则,Server对象承受了太多,也不符合单一职责。

2.Connector 和 Container

如何解决请求监听和请求处理耦合度很高的问题?加一层就好。

  • Connector

    Connector负责开启socket并且监听客户端请求,返回响应数据。

  • Engine

    Engine负责处理具体的请求

如是我们有下面这种设计

image-20230507180552182

这种设计需要server维护Connector和Engine的关系,才可以将Connector的请求交给对应Engine

并且无法做到一个Tomcat服务器运行多个服务,比如订单服务,用户服务。将Connector和Engine都交给Server处理,无法实现服务间的隔离。

3.Service

如何实现服务间的隔离?加一层就好

Server表示Tomcat服务器,一个Tomcat服务器可以部署多个服务,比如订单服务,用户服务。这里的服务就是Service。

image-20230507180753214

由Service负责当前自己服务中的维护Connector 和 Engine,Server负责管理多个服务

4.Context,Host,Wrapper

  • Context

    应用服务器是用来部署并允许web应用的,是一个运行环境,而不是一个独立业务处理系统,因此在Engine容器需要支持管理web应用,这里便是使用Context来表示一个web应用

  • Host

    Tomcat除了可以支持多个web应用之外,还需要可以支持多域名服务,比如一个主机可以承担多个域名,比如newx.cuzz.com,game.cuzz,com。因此需要把每一个域名视为一个虚拟主机,在每一个虚拟主机下包含多个web应用。

  • Wrapper

    在一个web应用中可以包含多个不同的servlet实例处理来自不同连接的请求,因此还需要一个组件的概念来表示tomcat中的servlet,这个组件就是Wrapper

image-20230507181204958

5.Container

Container表示一类组件,它们负责接受来自客户端的请求,并返回响应数据,这个过程往往会委托其他组件去完成,但是本质上它们是一致的——都是接受请求,返回响应数据。

Container表示容器,可以添加并维护子容器,因此Engine,Host,Context,Wrapper均继承自Container

image-20230507181756809

Container还提供了backgroundProcess方法,方便子类实现后台任务

6.Lifecycle

可以看到上图中组件都存在start,stop等生命周期方法,因此Tomcat抽象出Lifecycle接口,表示生命周期,定义了init,start,stop,destory等生命周期回调方法。并且还提供了LifecycleListener使用监听器模式来实现生命周期事件监听。

image-20230507182559565

7.Pipeline和Valve

为了增强扩展性,tomcat定义了Pipeline(管道)和Valve(阀),Pipeline使用职责链的方式串联多个Valve——来自客户端的请求如同流水一样流淌在管道中,收到每一个阀的作用。

image-20230507184619665

Pipeline中维护了基础的Valve,始终位于Pipeline末端,通过Pipeline#addValve添加的Valve违约基础的Valve之前。

在Tomcat中Engine,Host,Context,Wrapper都有对应的Valve实现,同时维护了一个Pipeline,从而让我们可以对请求的处理进行扩展。

image-20230507185116208

8.Connector设计

一个Connector处理请求的流程大致如下

image-20230507185822807

这些操作会被委托给Endpoint,ProtocolHandler,Processor

  • Endpoint:tomcat中没有这个接口,只有AbstractEndpoint,它负责启动线程来监听服务器端口,并且在接受到数据后交给Processor处理
  • Processor:Processor读取到客户端请求后按照请求地址映射到具体的容器进行处理,这个过程请求映射,Processor实现请求映射依赖于Mapper对象,在容器发生注册和注销的时候,MapperListener会监听到对应的事件,从而来变更Mapper中维护的请求映射信息。
  • ProtocolHandler:协议处理器,针对不同的IO方式(NIO,BIO等)和不同的协议(Http,AJP)具备不同的实现,ProtocolHandler包含一个Endpoint来开启端口监听,并且包含一个Processor用于按照协议读取数据并将请求交给容器处理。

image-20230507193102849

在次之外Tomcat 还有一个Adapter接口,上面说到Processor会依赖Mapper实现请求映射,但是其实Proccessor并没有直接持有一个Mapper,而是持有一个Adapter,由Adapter负责实现请求映射并交由Container处理请求。Adapter在Tomcat中只有一个实现CoyoteAdapter。

CoyoteAdapter在Processor和 Mapper以及Container中横插一脚,实现Connector和Mapper以及Container的解耦。

image-20230507202413947

结合tomcat整体架构后的图

image-20230507203258251

9.Executor

Tomcat定义了Executor接口,只有一个实现类StandardThreadExecutor,目的是为了实现tomcat组件间的线程池共享,并且这个线程池由Service进行管理,即同一个Server中的组件可以共享一个线程池。

image-20230507203145137

10 Bootstrap与Catalina

Tomcat通过类Catalina提供了一个Shell程序,用于解析server.xml创建各个组件。同时,负责启动、停止应用服务器(启动tomcat顶层组件Server)

Tomcat提供了Bootstrap作为应用服务器启动入口,Bootstrap负责反射创建Catalina实例,根据执行参数调用Catalina相关方法完成针对应用服务器的操作(启动、停止)。

在Tomcat发布包中,Bootstrap位于$CATALINA_HOME/bin下,和Tomcat应用服务器完全松耦合(通过反射调用Catalina实例),它可以直接依赖JRE运行并为Tomcat应用服务器创建共享类加载器,用于构造Catalina实例及整个Tomcat服务器。
image-20230507215430206
image-20230507213104299

二丶Tomcat启动流程

image-20230507213047804

可以看到Tocmat的启动流程非常标准化,这得益于这些组件都实现了Lifecyle接口。首先是调用init初始化组件,然后调用start方法启动组件,每次调用都伴随着生命周期事件的触发。

三丶Tomcat处理一个请求的流程

应用程序的请求处理,开始于监听服务器socket端口接受到数据,结束与服务器处理结果写入Socket输出流。

在此过程中,服务器需要将请求内容按照协议内容进行解析,封装为对象,然后根据请求映射规则定位到具体Servlet,这个Servlet中就是我们业务逻辑(SpringMVC中是DispatcherServlet将进一步将请求分发到Controller)Servlet处理结束后,响应对象将按照协议内容写如输出流。

image-20230507214918965

标签:架构,请求,Tomcat,处理,流程,Server,Connector,组件
From: https://www.cnblogs.com/cuzzz/p/17380267.html

相关文章

  • 架构设计概要
    架构设计的5大要素高性能高可用:限流、降级、灾备可扩展:增加防腐层(接口适配器层)、IOC、可伸缩安全性:物理安全性、系统安全性、数据安全性 架构设计原则合适优于业界领先简单优于复杂演化优于一步到位 架构设计的主要内容搞清楚内部元素关系元素的种类:系统、子系统、模......
  • 流程控制
    引子流程控制即控制流程,具体指控制程序的执行流程,而程序的执行流程分为三种结构:顺序结构(之前我们写的代码都是顺序结构)、分支结构(用到if判断)、循环结构(用到while与for)分支结构什么是分支结构分支结构就是根据条件判断的真假去执行不同分支对应的子代码为什么要用分支结构人......
  • 分布式架构整体框架
    文章目录一、分布式整体框架图1.架构eg12.架构eg2二、什么是分布式系统?1.什么是分布式系统?2.分布式系统的挑战3.分布式系统特性与衡量标准4.组件、理论、协议5.概念与实现6.总结三、分布式学习最佳实践:从分布式系统的特征开始(附思维导图)1.分布式特征的思维导图2.分布式系统的一般特......
  • Tomcat 配置SSL证书
    1.将证书放到tomcat或tomcat子目录下(如tomcat/conf等)2.修改tomcat/conf下的server.xml文件找到如下注释下的配置并修改:<!--DefineaSSLHTTP/1.1Connectoronport8443ThisconnectorusestheJSSEconfiguration,whenusingAPR,theconnectorsho......
  • mac m1 安装tomcat
    macm1安装tomcat下载tomcatzip包https://tomcat.apache.org/download-90.cgi解压到某个目录/Users/benjie/software/apache-tomcat-9.0.74配置环境变量#tomcatconfigexportTOMCAT_HOME=/Users/benjie/software/apache-tomcat-9.0.74exportPATH=$PATH:$TOMCAT_HOME/......
  • Linux驱动开发笔记(一):helloworld驱动源码编写、makefile编写以及驱动编译基本流程
    前言  基于linux的驱动开发学习笔记,本篇是描述了一个字符驱动的基础开发流程,以便做嵌入式开发多年的应用或者系统学习驱动开发。 笔者自身情况  笔者拥有硬件基础,单片机软硬基础,linux系统基础等各种,就是没有linux驱动框架基础,未做过linux系统移植和驱动移植开发了......
  • IDEA导入SpringMvc文件-Tomcat部署web的文件
                    ......
  • 机器学习系统架构的10个要素
    这是一个AI赋能的时代,而机器学习则是实现AI的一种重要技术手段。那么,是否存在一个通用的通用的机器学习系统架构呢?在老码农的认知范围内,Anythingisnothing,对系统架构而言尤其如此。但是,如果适用于大多数机器学习驱动的系统或用例,构建一个可扩展的、可靠的机器学习系统架构还是可......
  • 微信小程序登录的流程
    微信登录的流程移动端的知识点上面黄色代表前端小程序需要完成的过程上面紫色代表微信官方接口需要完成的过程上面蓝色代表idea服务器需要完成的过程1.用户前端/微信小程序获取随机生成的授权码code2.小程序发请求去登录(小程序携带授权码code)---从前端到后端携带授权......
  • 架构师的标准
    一个架构师必备的素质:如果你想知道什么才是真正的架构师,真正的架构师应有的素质是什么,那么我推荐你看一篇非常好的文章:http://www.infoq.com/cn/articles/brown-are-you-a-software-architect......