Tomcat系统架构与原理剖析

tomcat基础架构

  • b/s 架构(浏览器/服务器模式)

  • 浏览器为客户端(发送http请求)-----> 服务器端

浏览器访问服务器的流程

  • 基于tomcat为b/s架构

  • 客户端访问服务器的流程

  • 客户端与服务器建立信任链接: 用户发送请求, 浏览器将发起TCP连接请求, 服务器接受并建立连接

  • 客户端向服务器发送数据请求: 生成Http格式的数据包, 发送请求数据包, 服务器解析Http格式的数据包

  • 服务器向客户端响应请求: 服务器执行请求, 生成Http格式的数据包, 发送响应数据包, 客户端解析Http格式的数据包

  • 客户端展示响应数据: 浏览器呈现静态数据给用户

  • 注意: 浏览器访问服务器采用的是Http协议, Http是应用层协议, 用于定义数据通信的格式, 具体的数据传输使用的是TCP/IP协议<浏览器访问服务器协议的转换, http协议为应用层协议即通信协议, 数据传输层采用的是TCP/IP协议>

page2image14725728.png

Tomcat系统总体架构

  • Tomcat是一个Http服务器, 能够接受并处理Http请求, 所以tomcat是一个http服务器

  • Tomcat是一个Servlet容器, Tomcat接受到请求之后, 会交给servlet容器处理, servlet容器通过servlet接口调用业务类

  • 注意: tomcat即按照servlet规范的要求实现了servlet容器, 同时也具备了Http服务器的功能

系统总体架构功能

  • 与客户端(浏览器)进行交互, 进行socket通信, 将字节流和Request/Response等对象进行转换

  • Servlet容器处理业务逻辑

Tomcat连接器组件coyote

coyote简介

Tomcat连接器的组件名称, 是对外的接口. 客户端通过coyote与服务器建立连接、发送请求并接受响应

  • 封装了底层网络通信协议(Socket请求及响应处理)

  • 使Catalina容器(容器组件) 与具体的请求协议及IO操作方式完全解藕

  • 将Socket输入转换封装为Request对象, 进一步封装后交由Catalina容器进行处理, 处理请求完成后, Catalina通过Coyote提供的Response对象将结果写入输出流

  • 负责的是具体协议(应用层)和IO(传输层)相关内容

對装.png

Coyote支持的IO模型与协议

page7image64833776.png

Coyote内部组件及流程

Connector.png
组件 做用描述
EndPoint EndPoint 是 Coyote 通信端点,即通信监听的接口,是具体Socket接收和发 送处理器,是对传输层的抽象,因此EndPoint用来实现TCP/IP协议的
Processor Processor 是Coyote 协议处理接口 ,如果说EndPoint是用来实现TCP/IP协 议的,那么Processor用来实现HTTP协议,Processor接收来自EndPoint的 Socket,读取字节流解析成Tomcat Request和Response对象,并通过 Adapter将其提交到容器处理,Processor是对应用层协议的抽象
ProtocolHandler Coyote 协议接口, 通过Endpoint 和 Processor , 实现针对具体协议的处 理能力。Tomcat 按照协议和I/O 提供了6个实现类 : AjpNioProtocol , AjpAprProtocol, AjpNio2Protocol , Http11NioProtocol , Http11Nio2Protocol ,Http11AprProtocol
Adapter 由于协议不同,客户端发过来的请求信息也不尽相同,Tomcat定义了自己的 Request类来封装这些请求信息。ProtocolHandler接口负责解析请求并生成 Tomcat Request类。但是这个Request对象不是标准的ServletRequest,不 能用Tomcat Request作为参数来调用容器。Tomcat设计者的解决方案是引 入CoyoteAdapter,这是适配器模式的经典运用,连接器调用 CoyoteAdapter的Sevice方法,传入的是Tomcat Request对象, CoyoteAdapter负责将Tomcat Request转成ServletRequest,再调用容器

Tomcat Servlet 容器 Catalina

Tomcat模块分层结构图及Catalina位置

Catalina是Tomcat的核心, Tomcat本质上就是一款Servlet容器. 其他模块都是为Catalina提供支撑的.

Servlet容器Catalina的结构

  • 整个tomcat就是一个Catalina实例, tomcat启动的时候会初始化这个实例, Catalina实例通过加载Server.xml完成其他实例的创建, 创建并管理一个Server, Server创建并管理多个服务, 每个服务又可以有多个Connector和一个Container

  • 绕口令

  • 一个Catalina容器, 一个Server实例和多个Service实例

  • 每个Service实例, 多个Connector实例和一个Catalina容器

  • 具体职责

  • Catalina : 负责解析Tomcat的配置文件(Server.xml), 以此来创建服务器Server组件并进行管理

  • Server : 服务器表示整个Catalina Servlet容器以及其它组件, 负责组装并启动Servlet引擎, Tomcat连接器. Server 通过实现Lifecycle接口, 提供一种优雅的启动和关闭整个系统的方式.

  • Service : 服务是Server内部的组件, 一个Server包含多个Service. 它将若干个Connector组件绑定到一个Container

  • Container : 容器, 负责处理用户的Servlet请求, 并返回对象给web用户的模块.

Container组件的具体结构

组件 组件描述
Engine 表示整个Catalina的Servlet引擎,用来管理多个虚拟站点,一个Service最多只能有一个Engine, 但是一个引擎可包含多个Host
Host 代表一个虚拟主机,或者说一个站点,可以给Tomcat配置多个虚拟主机地址,而一个虚拟主机下可包含多个Contex
Context 表示一个Web应用程序, 一个Web应用可包含多个Wrapper
Wrapper 表示一个Servlet,Wrapper 作为容器中的最底层,不能包含子容器
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 198,848评论 5 466
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 83,529评论 2 375
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 145,824评论 0 327
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 53,329评论 1 268
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 62,227评论 5 359
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 47,879评论 1 275
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,218评论 3 390
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,877评论 0 254
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,159评论 1 294
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,155评论 2 315
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,987评论 1 328
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,736评论 3 316
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,273评论 3 302
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,407评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,663评论 1 255
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,158评论 2 344
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 41,517评论 2 339

推荐阅读更多精彩内容