一次请求的来龙去脉 – Tomcat架构解析(二)

容器,简单理解就是用来装东西的工具。在Tomcat里面,容器被设计用来装载Servlet, 也就是我们平常写的普通的Servlet ,就会存放在容器里面。这也就是咱们平常念叨的Servlet容器,其实从广义上理解,Servlet容器是指Tomcat,从狭义上理解,Servlet容器,只是Tomcat里面的一个组件而已。

1. 容器概述

Tomcat采用分层结构设计了4种容器,这4种容器分别是: Engine 、Host 、Context 、Wrap 。它们钧继承 Container 容器接口。这样设计使得Tomcat在处理请求时,分工更加明确,也使得容器具有很好的灵活性。

一次请求的来龙去脉 - Tomcat架构解析(二)

其中从左到右: Engine 表示引擎,用来管理多个虚拟站点,一个Service最多只能有一个Engine。 Host代表虚拟主机,或者表示站点。其实就是我们配置出来的虚拟映射地址。Context表示一个Web应用,Wrap 名为包装,它其实就是内部包装着我们写的Servlet。

为了方便大家理解,我们可以从Tomcat里面的server.xml中看出来一些端倪。

一次请求的来龙去脉 - Tomcat架构解析(二)

这四个容器呈现的是一个父子包含关系:

一次请求的来龙去脉 - Tomcat架构解析(二)
2. 定位Servlet

在Tomcat里面使用Mapper 映射器来实现Servlet的定位工作。在最初启动项目的时候,Tomcat就开始解析了项目的配置信息,然后使用Mapper来保存了具体的映射地址和Host、Context、Wrap的对应关系。当请求到来的时候,就会到Mapper里面去查找匹配的Wrap(Servlet),然后调用。当我们为了方便理解,我们可以浅显的认为Mapper其实就是一个类似Map键值对的容器。

2.1 全局概览

比如: 下面的图示,我们可以把瑞吉点餐项目的面向管理员后台项目和面向用户前端项目部署在同一个Tomcat上,为了隔离它们,我们通过配置虚拟域名,也就是两个Host。而用户系统,订单系统,产品系统,购物车系统又都是可以独立运行的应用,所以我们可以配备4个Context来对应它们。最后一排的Wrap,其实就是各自系统中的Servlet了。

一次请求的来龙去脉 - Tomcat架构解析(二)
2.2 请求到来

此时用户使用

http://user.reggie.com:8080/cart/delete 来访问。 2.2.1 定位Service和Engine

由于来访的时候,使用的是8080端口,正好被Http连接器捕捉到。在Tomcat里面,Service里面包含着: 连接器和容器。找到了连接器,也就意味着找到了容器,这也就意味着Engine就确定了。

2.2.2 定位Host

Service和Engine确定了之后,就在Mapper中,通过路径地址,找到响应的Host容器。由于使用的是user.reggie.com 访问,所以这就确定了是Host2这个容器。

2.2.3 定位Context

Host确定了之后,继续在Mapper中查找。由于使用的/cart访问,所以这就定位到了Context4这个应用。

2.2.4 定位Wrap

Context确定了之后,后续也就能根据地址 /delete,轻而易举的找到 Wrap6 这个容器。最后也就定位到了Servlet。

2.3 请求传递

Tomcat 里面是如何把请求从最外层的容器Engine,一直往里传递到Wrap,然后执行Servlet的调用的呢?

答案是使用 Pipeline-Valve 管道。

Pipeline-Valve 是责任链模式,责任链模式是指在一个请求处理的过程中有很多处理者依次对请求进行处理,每个处理者负责做自己相应的处理,处理完之后将再调用下一个处理者继续处理。

下面通过一个张简单的草图来描述:

每一个容器都有一个Pipeline对象,中间的每一个圆圈,其实表示的是一个Valve,它表示处理点。在Pipeline里面维护这Valve的链表。只要执行了第一个Pipeline的Valve,这个容器中的Pipeline就会被调用,直到最后末端的Basic的Valve,它负责去连接下一个子容器的第一个Valve处理点。这样不断的串联起来,最终就到达了Servlet。

一次请求的来龙去脉 - Tomcat架构解析(二)

值得注意的是: 在Wrap的最后一个Basic的Valve的处理点里面,它会创建一个Filter过滤器链,然后在doFilter方法中最终调用Servlet的service方法。

3. 总结

本文主要给大家描述了Tomcat了里面的容器结构,以及请求到来的时候,是如何识别到底执行了哪个Servlet。请求的链式调用是基于 Pipeline-Valve 责任链来完成的,这样的设计使得系统具有良好的可扩展性,如果需要扩展容器本身的功能,只需要增加相应的 Valve 即可。

免责声明:文章内容来自互联网,本站仅作为分享,不对其真实性负责,如有侵权等情况,请与本站联系删除。
转载请注明出处:一次请求的来龙去脉 – Tomcat架构解析(二) https://www.dachanpin.com/a/cyfx/11397.html

(0)
上一篇 2023-05-12 03:15:23
下一篇 2023-05-12 03:16:26

相关推荐

  • 如何在朋友圈刷品牌存在感?来学学“新微商”都怎么玩的

      A5创业项目春季招商 好项目招代理无忧   现在微商是这样玩转朋友圈的:在为产品打call的同时,还会与读者建立深层关系和信任感。我们把他们的朋友圈从外到内拆解,留心哪些是值得我们借鉴的亮点。   微信朋友圈,自从被微商、代购、安利、晒娃、炫富、自拍等攻占后,已经渐渐沦为大家的吐槽阵地,甚至成为鄙视链的末端。连笔者最初看到微商的朋友圈,也为自己随便加微商…

    创业分享 2023-05-19
    71
  • 双创部《遇见更好的自己~创业分享会》特别活动在宁开展

    相关新闻   双创部全体成员合影留念 标签:合影;江苏省;欧美同学会   江苏省欧美同学会青委会秘书长李莹对青委会相关情况进行了详细介绍,让众多新进海归青年了解到组织的职能和发展方向,更进一步加深了解促进凝聚力。 11月18日上午,江苏省欧美同学会(江苏省留学人员联谊会)青年工作委员会(以下简称青委会)创新创业部组织策划的《遇见更好的自己~创业分享会》特别活…

    2023-05-23
    96
  • 韦韬:玉林建区域性大城市 邀侨胞支持参与家乡建设发展

    广西玉林市市长韦韬致辞。  俞靖 摄   中新网广西新闻9月15日电(记者 杨志雄 黄艳梅)广西玉林市市长韦韬15日称,玉林玉林市将大力实施“五大战略”,加快推进“四大攻坚”,确保“十三五”期间与全国全区同步全面建成小康社会,基本建成区域性大城市、国家非公经济发展示范市和北部湾城市群商贸中心。玉林市殷切期盼广大侨胞一如既往地关心、支持家乡的建设和发…

    2023-05-16
    89
  • 创业板指跌超1% 市场出现调整拐点?基金该怎么投?

    、、等大市值蓝筹依旧频频出现,除宁德时代、、恒瑞医药、数据显示,截至2019年末,近1年新华基金旗下权益基金绝对收益率为41.52%,排名126个公募基金管理人前1/3行列,近5年权益基金绝对收益率为98.77%,在73个公募基金管理人中排名第13。 (责任编辑:DF519)   从具体产品的表现看,银河证券数据显示,截至2月7日,新华外延增长主题过去1年收…

    2023-05-12
    65
  • “红顶商人”张旭升出狱后召旧部再创业:不信东风唤不回

    “红顶商人”张旭升出狱后召旧部再创业:不信东风唤不回 来源:中国江苏网   作者:陈威   2018-02-05 16:34:00 张旭升,江苏省一剪梅集团董事长,曾因身陷囹圄导致企业遭贱卖,经历了人生的大起大落。   张旭升,江苏省一剪梅集团董事长,曾因身陷囹圄导致企业遭贱卖,经历了人生的大起大落。如今,年近花甲的张…

    创业分享 2023-05-20
    200

发表回复

登录后才能评论

联系我们

在线咨询: QQ交谈

邮件:362039258@qq.com

工作时间:周一至周五,9:30-16:30,节假日休息