Tomcat大家都知道,这个没什么好描述的,我们先看Tomcat的总体架构

1、总体架构

架构一步一步增加组件,先来个最原始的

===

Server:Tomcat的整体服务,负责接收和处理请求。其拥有生命周期start开启和stop关闭方法。

但是很明显,所有操作放到Server里面来是不可能的,我们继续往下扩展

===

除开Server还加入了Connector、Container。

Connector连接器:使用Socket来接收请求的到来,并对请求进行响应。

Container容器:用来接收具体的请求,进行处理。

引入后流程就是这样了,Connector接受请求后让Container进行处理,然后再返回给用户

但是这个也有问题,缺少请求之间的映射规则。

===

一个Server下多个Service,一个Service下维护多个Connector和Container,那么此时每个Connector只能给指定的Container处理请求。

这里Container意为容器,我们更改其名称为Engine引擎。

下面我们再将Engine往下细分。

===

这里新加入 了 Context。

Context:代表一个Web应用,那么我们肯定可以有多个的Context

然后我们再往下细化。

5

这里我们需要将域名抽象为虚拟主机,所以定义了Host。

再细分

===

我们一个Wrapper则为一个Servlet。

我们上面将Container去掉了,其实我们这里可以把Engine、Host、Context、Wrapper都堪称Container的子类。

===

图里面组件都同属于同一个生命周期类Lifecycle。

2、启动流程与源码解析

Tomcat启动流程分为两大步:load和start

启动类名为:BootStrap,在我们tomcat的bin中startup命令中,其实就是启动的BootStrap这个类的main方法。

位置:org.apache.catalina.startup.Bootstrap#main

首先是创建BootStra实例,然后调用init方法,并将实例赋值给daemon。

然后进入到下面的方法中,首先是进入deamon(bootstrap)的load方法中。

然后我们进入Bootstrap的load方法中去:

注意这里会去调用catalinaDaemon的load方法,这里是catalinaDaemon为Catalina(org.apache.catalina.startup.Catalina)。

注意在我们Catalina的load方法中。会去获取到Server,此Server为StandardServer,然后去调用其init方法。

注意此处叨到达了我们生命周期父类的init方法中,因为我们的StandardServer并未实现init方法,而是使用initInternal方法,所以我们进入StandardServer的initInternal方法。

注意在StandardServer中,它要开始去调用获取到的多个Service,并挨个初始化,注意我们前面架构图中说了,一个Server是多个Service的。

这里只有一个Service,其为StandardService,这里和Server一样,会去调用生命周期父类的init方法,然后我们进入StandardService的initInternal方法。

这里首先是初始化Engine,其为StandardEngine,里面没有其他操作,这里就不列出来。

然后就是初始化Executor线程池。

然后初始化Connector连接器。注意这里面还有其它初始化的操作,进入其中init方法。

注意这里的protocolHandler是协议处理器,当前这个类的名称叫做Http11NioProtocol,其代表HTTP1.1,NIO代表运行模式,还有bio,nio,nio2,apr这几种模式。

进入Http11NioProtocol的父类的init方法中。

EndPoint为NioEndPoint,其是实现了IO多路复用的组件,其这里不过多解释。

至此BootStrap的load方法结束,我们继续看它的start方法。

其进如Catania的start方法中。

其Catania中进入StandardServer的start方法中,其父类会调用StandardServer的startInternal方法。

可以看到这里面会去执行StandardService的start方法。

依次执行StandardEngine、Executor、Connector的start方法。

然后我们看Connector的startInternal方法。

在进入NioEndPoint父类AbstractEndpoint中start方法,再进入其NioEndPoint的startInternal方法。最后总体架构中所有组件已经完成初始化。

其实这里面还应该有HOST、Wrapper等的初始化操作的,其存在于start方法当中,这个比较复杂后续写上记录。

最后附上时序图:

Tomcat总体架构和启动流程的更多相关文章

  1. 理解Tomcat架构、启动流程及其性能优化

    PS:but, it's bullshit ! 备注:实话说,从文档上扒拉的,文档地址:在每一个Tomcat安装目录下,会有一个webapps文件夹,里面有一个docs文件夹,点击index.html ...

  2. Tomcat架构解析(一)-----Tomcat总体架构

    Tomcat是非常常用的应用服务器,了解Tomcat的总体架构以及实现细节,对于理解整个java web也是有非常大的帮助. 一.Server   1.最简单的服务器结构 最简单的服务器结构如图所示: ...

  3. tomcat总体架构

    Tomcat 总体结构图 从上图中可以看出Tomcat的心脏是两个组件:Connector 和 Container,关于这两个组件将在后面详细介绍.Connector 组件是可以被替换,这样可以提供给 ...

  4. Tomcat 第二篇:启动流程

    1 Tomcat 基本知识 首先介绍一些 Tomcat 的基本知识,防止有纯小白看的云里雾里的. 下面这张图是一个下载好二进制版的的 Tomcat ,直接解压得到的,虽然版本是 9.x ,但是这个目录 ...

  5. Android系统架构及启动流程

  6. Tomcat 第三篇:总体架构设计

    Tomcat 总体架构设计 在开始这篇文章的时候,忽然发现上一篇内容的题目不是很合适,不应该叫启动流程,更确切的应该是叫启动脚本. 在最开始,先介绍下 Tomcat 的总体设计,先有一个大概的印象,对 ...

  7. Tomcat源码解析-整体流程介绍

    一.架构 下面谈谈我对Tomcat架构的理解 总体架构: 1.面向组件架构 2.基于JMX 3.事件侦听 1)面向组件架构 tomcat代码看似很庞大,但从结构上看却很清晰和简单,它主要由一堆组件组成 ...

  8. 步步深入MySQL:架构->查询执行流程->SQL解析顺序!

    一.前言 一直是想知道一条SQL语句是怎么被执行的,它执行的顺序是怎样的,然后查看总结各方资料,就有了下面这一篇博文了. 本文将从MySQL总体架构--->查询执行流程--->语句执行顺序 ...

  9. Phalcon Framework的MVC结构及启动流程分析

    目前的项目中选择了Phalcon Framework作为未来一段时间的核心框架.技术选型的原因会单开一篇Blog另说,本次优先对Phalcon的MVC架构与启动流程进行分析说明,如有遗漏还望指出. P ...

  10. Tomcat启动流程简析

    Tomcat是一款我们平时开发过程中最常用到的Servlet容器.本系列博客会记录Tomcat的整体架构.主要组件.IO线程模型.请求在Tomcat内部的流转过程以及一些Tomcat调优的相关知识. ...

随机推荐

  1. flink udaf函数

    1.Flink-sql自定义UDAF函数 - 简书 (jianshu.com) 2.Flink SQL 自定义UDAF_k_wzzc的博客-CSDN博客_flink udaf 3.Flink 实践教程 ...

  2. centos7 添加自定义程序为系统服务

    centos6版本的系统服务是/etc/init.d启动脚本的方式,centos7采用强大的systemctl来管理系统服务,大幅提供了系统服务的运行效率,但是服务的配置和以前版本完全不同,这是很大的 ...

  3. Tomcat 的连接数与线程池

    一.背景 在使用tomcat时,经常会遇到连接数.线程数之类的配置问题,要真正理解这些概念,必须先了解Tomcat的连接器(Connector). 在前面的文章 Tomcat配置文件server.xm ...

  4. springboot+mybais配置多数据源(分包实现)

    一.分包方式实现: 1.在application.properties中配置两个数据库: #druid连接池 #dataSoureOne(这里是我本地的数据源) spring.datasource.o ...

  5. 03、如何理解Kafka和Zookeeper的关系

    001.Kafka简介 Apache Kafka最早是由Linkedin公司开发,后来捐献给了Apack基金会. Kafka被官方定义为分布式流式处理平台,因为具备高吞吐.可持久化.可水平扩展等特性而 ...

  6. nodejs 程序打包 打包 koa express 项目 源代码保护加密

    打包项目 几个可以 把 nodejs 打包成单个文件的库,为了方便或保护源代码,都可以尝试,打包完成需要测试,如果项目有特殊依赖,可能会失败. https://github.com/nexe/nexe ...

  7. js-禁止鼠标右键/禁止选中文字

    1 <p>使用contextmenu禁止鼠标右键</p> 2 <script> 3 document.addEventListener('contextmenu', ...

  8. 记一次mybatis中like 不执行sql的问题,单引号 与双引号的坑

    使用环境: springboot 2.0.4 mybatis-spring:1.3.2 错误也是比较蛋疼:  不报错,但是查询出来的结果不对. 原错误sql 示意:  select  * from  ...

  9. OutLook从excel导入联系人

    1.将已有的excel打开-->另存为-->csv格式 2.用记事本打开 .CSV 文件,选择"文件"-"另存为",修改为  ANSI编码后,然后导 ...

  10. 如何保证RabbitMQ的消息不会丢失?怎么保证RabbitMQ的可靠性?

    生产者: 原因: 由于网络原因导致消息发送失败,消息队列没有接收到生产者发送的消息,但生产者认为消息发送成功. 解决办法: transaction模式:事务模式:开启事务,发送消息,成功提交事务,失败 ...