Tomcat 总体架构

开篇

 首先一定要先感谢《Tomcat架构解析》一书的作者刘光瑞,对于我这样的新手来说,这本书关于Tomcat总体架构的介绍能够让我快速的了解整个架构的设计背景,达到了循序渐进的目的,在这里非常推荐新手入手一本。

本篇博文的图片都是截取自《Tomcat架构解析》一书,为了能够截图我下载了这书的电子版,不过我也是身体力行的购买正版书在支持的,也非常希望技术人员能够尊重原创的成果。

 最后这个章节主要是介绍Tomcat整体架构的,整体内容主要在于模块介绍以及关联,希望通过这个章节能够串通所有模块让大家有个整体的架构


Tomcat总体架构介绍

整体架构

<Server>
    <Service>
        <Connector />
        <Connector />
        <Engine>
            <Host>
                <Context /><!-- 现在常常使用自动部署,不推荐配置Context元素,Context小节有详细说明 -->
            </Host>
        </Engine>
    </Service>
</Server>


说明:
Tomcat的Server配置主要包括Server、Service、Connector、Engine、Host、Conetext,整体的架构如上图,各个组件的功能介绍如下:

  • Server:一个Server包含多个Service,一个Service维护多个Connector和一个Container(Tomcat将Container重命名为Engine,用以表示servlet引擎)。
  • Connector:负责开启Socket监听客户端请求。
  • Engine:Tomcat将Container重命名为Engine,用以表示servlet引擎,包含多个Host。
  • Host:提供虚拟机主机功能,一个Engine下包含多个虚拟主机功能。
  • Context:用以表示一个web应用,并且一个Engine可以包含多个Context。
  • Wrapper:Tomcat将servlet定义为Wrapper。


整体架构 - 增加生命周期


说明:

  • 各组件模块实现Lifecycle接口,用于各组件生命周期的管理。
  • Container接口提供子容器的添加,Engine&Host&Context&Wrapper均实现该接口。


整体架构 - 增加职责链


说明:

  • Tomcat采用职责链的模式来实现客户端请求的处理
  • Tomcat定义了PipeLine(管道)和Valve(阈)两个接口,前者用于构造职责链,后者代表职责链上的每个处理器。


整体架构 - Connector细化


说明:

  • ProtocolHandler表示协议处理器,针对不同的协议和IO方式提供不同的实现。
  • AbstractEndpoint负责启动线程监听端口,接收请求后调用Processor进行数据读取。
  • Mapper维护容器映射关系,同时按照映射规则查找容器。
  • MapperListener用于在容器状态发生变更时,注册或者取消对应的容器映射信息。
  • CoyoteAdapter实现了Connector和Mapper和Container的解耦,


整体架构 - 增加线程池


说明:

  • Tomcat提供了Executor接口来表示一个可以在组件间共享的线程池。
  • Endpoint在接收到客户端请求后,会创建请求处理对象并交由线程池处理。


整体架构 - 组件功能介绍

Tomcat功能组件介绍
Tomcat功能组件介绍
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。