您当前的位置:首页 > 电脑百科 > 站长技术 > 服务器

Tomcat 整体架构分析

时间:2021-09-30 12:30:20  来源:  作者:指尖代码

1. 整体架构简析#

如果将Tomca它的结构高度抽象的话,那么Tomcat其实可以看成只是有连接器(Connector)和容器(Container)两个组件构成。其中Connector组件负责在服务器端处理客户端连接,包括接收客户端连接、接收客户端的消息报文以及消息报文的解析等工作,而Container组件则负责对客户端的请求进行逻辑处理,并把结果返回给客户端。Container组件其实可以再细分,分成Engine组件、Host组件、Context组件和WrApper组件。

Tomcat 整体架构分析

 

从Tomcat服务器配置文件server.xml的内容格式看,它所描述的Tomcat也符合上图的层级结构,以下便是server.xml简洁的配置节点,所以从server.xml文件也能看出Tomcat的大体结构:

<? xml version='1.0' encoding='utf-8'? >
<Server>
    <Listener/>
    <GlobalNamingResources>
    <Resource/>
    </GlobalNamingResources>
    <Service>
        <Executor/>
        <Connector/>
        <Engine>
            <Cluster/>
            <Realm/>
            <Host>
            <Context/>
            </Host>
        </Engine>
    </Service>
</Server>

2. Server组件#

Server是最顶级的组件,它代表Tomcat的运行实例,在一个JVM中只会包含一个Server。在Server的整个生命周期中,不同阶段会有不同的事情要完成。为了方便扩展,它引入了监听器方式,所以它也包含了Listener组件。另外,为了方便在Tomcat中集成JNDI,引入了GlobalNamingResources组件。同时,还包含了Service核心组件。

<? xml version='1.0' encoding='utf-8'? >
<Server>
    <!-- 配置一个或多个Listener -->
    <Listener/>
    <!-- 配置JNDI资源 -->
    <GlobalNamingResources>
    	<Resource/>
    </GlobalNamingResources>
    <!--配置一个或多个Service-->
    <!--注意一个Tomcat实例中可以配置多个Service,这些Service通过监听不同的端口来区分-->
    <Service>
		...
    </Service>
</Server>

Server组件在Tomcat中的实现类是StandardServer,除了表示Service的一个对象数组外,主要是一些关于Tomcat的属性,比如port,address等。

3. Service组件#

Service组件是连接器(Connector)和容器(Container)的组合。一个Tomcat实例中可以有多个Service组件,它们彼此独立。StandardService是Service组件的实现类。如果上面的Server组件代表Tomcat服务器实例的话,那么Service组件就是这个服务器上面对外提供的一个个具体的服务。这个服务监听着不同的端口,你要访问哪些服务必须指定这些服务对应的端口。这样一类比的话就和具体的硬件服务器很像。

public class StandardService extends LifecycleMBeanBase implements Service
{
    private Server server = null;
    protected Connector connectors[] = new Connector[0];
    private Engine engine =null;
    protected final Mapper mapper = new Mapper();
}

server表示其所属Server,Engine作为处理该service中Connector的容器。Mapper可以看作是映射器,要来处理请求地址到处理该请求的容器及Servlet的映射。

Tomcat 整体架构分析

 

另外,service组件还有一个Executor组件,这个线程池组件可以让多个连接器组件共享,而不是每个连接器组件都使用自己的线程池。

4. Connector组件#

Tomcat 整体架构分析

 

表示Tomcat中的连接器,其主要作用是监听并转化Socket请求,并交由Container处理。其实就是对不同协议及协议处理器进行的封装。下面是我们需要关注的几个属性域:

public class Connector extends LifecycleMBeanBase
 {
	protected Service service = null;
    protected final ProtocolHandler protocolHandler;
}

不同的协议会对应不同的Connector,目前Tomcat支持HTTP(HTTPS)和AJP两种协议的Connector。另外同一种协议的内部也会根据网络IO方式的不同分为阻塞IO和非阻塞IO。下面以HTTP协议为例子简单介绍:

Tomcat 整体架构分析

 

  • Http11Protocol组件,是HTTP协议1.1版本的抽象,它包含接收客户端连接、接收客户端消息报文、报文解析处理、对客户端响应等整个过程。它主要包含JIoEndpoint组件和Http11Processor组件。启动时,JIoEndpoint组件内部的Acceptor组件将启动某个端口的监听,一个请求到来后将被扔进线程池Executor,线程池进行任务处理,处理过程中将通过Http11Processor组件对HTTP协议解析并传递到Engine容器继续理。
  • Mapper组件,客户端请求的路由导航组件,通过它能对一个完整的请求地址进行路由,通俗地说,就是它能通过请求地址找到对应的Servlet。
  • CoyoteAdaptor组件,一个将Connector和Container适配起来的适配器。
Tomcat 整体架构分析

 

如上图所示,在非阻塞I/O方式下,Connector的结构类似阻塞模式,Http11Protocol组件改成Http11NioProtocol组件,JIoEndpoint组件改成NioEndpoint, Http11Processor组件改成Http11NioProcessor组件,这些类似的组件的功能也都类似。唯独多了一个Poller组件,它的职责是在非阻塞I/O方式下轮询多个客户端连接,不断检测、处理各种事件,例如不断检测各个连接是否有可读,对于可读的客户端连接则尝试进行读取并解析消息报文。

5. Engine组件#

Tomcat内部有4个级别的容器,分别是Engine、Host、Context和Wrapper。Engine代表全局Servlet引擎,每个Service组件只能包含一个Engine容器组件,但Engine组件可以包含若干Host容器组件。除了Host之外,它还包含如下组件。

  • Listener组件:可以在Tomcat生命周期中完成某些Engine容器相关工作的监听器。
  • AccessLog组件:客户端的访问日志,所有客户端访问都会被记录。
  • Cluster组件:它提供集群功能,可以将Engine容器需要共享的数据同步到集群中的其他Tomcat实例上。
  • Pipeline组件:Engine容器对请求进行处理的管道。
  • Realm组件:提供了Engine容器级别的用户-密码-权限的数据对象,

6. Host组件#

Tomcat中Host组件代表虚拟主机,这些虚拟主机可以存放多个Web应用的抽象(Context容器)。除了Context组件之外,它还包含如下组件。

  • Listener组件:可以在Tomcat生命周期中完成某些Host容器相关工作的监听器。
  • AccessLog组件:客户端的访问日志,对该虚拟主机上所有Web应用的访问都会被记录。
  • Cluster组件:它提供集群功能,可以将Host容器需要共享的数据同步到集群中的其他Tomcat实例 上。
  • Pipeline组件:Host容器对请求进行处理的管道。
  • Realm组件:提供了Host容器级别的用户-密码-权限的数据对象,配合资源认证模块使用。

7. Context组件#

Context组件是Web应用的抽象,我们开发的Web应用部署到Tomcat后运行时就会转化成Context对象。它包含了各种静态资源、若干Servlet(Wrapper容器)以及各种其他动态资源。它主要包括如下组件。

  • Listener组件:可以在Tomcat生命周期中完成某些Context容器相关工作的监听器。
  • Filter组件:过滤器组件,提供统一的业务逻辑处理。
  • AccessLog组件:客户端的访问日志,对该Web应用的访问都会被记录。
  • Pipeline组件:Context容器对请求进行处理的管道。
  • Realm组件:提供了Context容器级别的用户-密码-权限的数据对象,配合资源认证模块使用。
  • Loader组件:Web应用加载器,用于加载Web应用的资源,它要保证不同Web应用之间的资源隔离
  • Manager组件:会话管理器,用于管理对应Web容器的会话,包括维护会话的生成、更新和销毁。
  • NamingResource组件:命名资源,它负责将Tomcat配置文件的server.xml和Web应用的context.xml资源和属性映射到内存中。
  • Mapper组件:Servlet映射器,它属于Context内部的路由映射器,只负责该Context容器的路由导航.
  • Wrapper组件:Context的子容器。

8. Wrapper组件#

Wrapper容器是Tomcat中4个级别的容器中最小的,与之相对应的是Servlet,一个Wrapper对应一个Servlet。它包含如下组件。

  • Servlet组件:Servlet即Web应用开发常用的Servlet,我们会在Servlet中编写好请求的逻辑处理。
  • ServletPool组件:Servlet对象池,当Web应用的Servlet实现了SingleThreadModel接口时则会在Wrapper中产生一个Servlet对象池。线程执行时,需先从对象池中获取到一个Servlet对象,ServletPool组件能保证Servlet对象的线程安全。
  • Pipeline组件:Wrapper容器对请求进行处理的管道。


Tags:Tomcat   点击:()  评论:()
声明:本站部分内容及图片来自互联网,转载是出于传递更多信息之目的,内容观点仅代表作者本人,如有任何标注错误或版权侵犯请与我们联系(Email:2595517585@qq.com),我们将及时更正、删除,谢谢。
▌相关推荐
1. 整体架构简析#如果将Tomca它的结构高度抽象的话,那么Tomcat其实可以看成只是有连接器(Connector)和容器(Container)两个组件构成。其中Connector组件负责在服务器端处理客户端...【详细内容】
2021-09-30  Tags: Tomcat  点击:(53)  评论:(0)  加入收藏
开源的 Java Web 应用服务器,实现了 Java EE(Java Platform Enterprise Edition)的部 分技术规范,比如 Java Servlet、Java Server Page、JSTL、Java WebSocket。Java EE 是 S...【详细内容】
2021-09-17  Tags: Tomcat  点击:(68)  评论:(0)  加入收藏
一、前言server.xml 配置,是 Tomcat启动配置,从配置结构可以看出 Tomcat 的整体架构。如果能够了解其常用配置项,对 Tomcat有一个高屋建瓴的把握,然后再庖丁解牛,一步步深入源码...【详细内容】
2021-07-04  Tags: Tomcat  点击:(86)  评论:(0)  加入收藏
一,undertow介绍 1,undertow简介:Undertow是RedHAT红帽公司开源的产品,采用java开发,是一款灵活,高性能的web服务器,提供了NIO的阻塞/非阻塞API,也是Wildfly的默认Web容器。在javaw...【详细内容】
2021-05-07  Tags: Tomcat  点击:(184)  评论:(0)  加入收藏
说明最近项目上遇到一些https的问题,需要在tomcat里面测试一下如何开启https协议访问网站,在网上查了一些资料,自己也试了很多次,终于成功搞定了,下面跟大家分享一下我的一点经验...【详细内容】
2021-04-20  Tags: Tomcat  点击:(162)  评论:(0)  加入收藏
1 Jetty与glassfish的基本介绍1.1 研究背景及意义下图是对几个主流的应用服务器使用比率的粗率统计结果做出的一个饼图。这个图的数据也许不够精确,但它还是可以在一定程度上...【详细内容】
2021-04-06  Tags: Tomcat  点击:(199)  评论:(0)  加入收藏
Tomcat是什么?Tomcat是web容器。你在做web项目时,多数需要http协议,也就是基于请求和响应,比如你在百度输入一行内容搜索,那么百度服务器如何处理这个请求呢,他需要创建servlet来...【详细内容】
2021-03-24  Tags: Tomcat  点击:(290)  评论:(0)  加入收藏
有这样一个场景,公司为了安全起见,需要对所有登录Linux服务器做安全限制,要求除了管理员其他要登录linux服务器的员工不能用最高权限账号登录,要创建新的用户,对目录及文件权限做...【详细内容】
2021-03-04  Tags: Tomcat  点击:(178)  评论:(0)  加入收藏
热部署就是在服务器运行时重新部署项目,热加载即在在运行时重新加载class,从而升级应用。通常情况下在开发环境中我们使用的是热加载,因为热加载的实现的方式在Web容器中启动一...【详细内容】
2021-03-03  Tags: Tomcat  点击:(210)  评论:(0)  加入收藏
制作tomcat镜像先找到一个要安装的版本我们这里以拉取tomcat8的官方镜像为例 1:拉取官方镜像docker pull tomcat:8 2:查看镜像并启动tomcat容器docker imagesdocker run -d -p...【详细内容】
2021-03-01  Tags: Tomcat  点击:(323)  评论:(0)  加入收藏
▌简易百科推荐
阿里云镜像源地址及安装网站地址https://developer.aliyun.com/mirror/centos?spm=a2c6h.13651102.0.0.3e221b111kK44P更新源之前把之前的国外的镜像先备份一下 切换到yumcd...【详细内容】
2021-12-27  干程序那些事    Tags:CentOS7镜像   点击:(1)  评论:(0)  加入收藏
前言在实现TCP长连接功能中,客户端断线重连是一个很常见的问题,当我们使用netty实现断线重连时,是否考虑过如下几个问题: 如何监听到客户端和服务端连接断开 ? 如何实现断线后重...【详细内容】
2021-12-24  程序猿阿嘴  CSDN  Tags:Netty   点击:(12)  评论:(0)  加入收藏
一. 配置yum源在目录 /etc/yum.repos.d/ 下新建文件 google-chrome.repovim /etc/yum.repos.d/google-chrome.repo按i进入编辑模式写入如下内容:[google-chrome]name=googl...【详细内容】
2021-12-23  有云转晴    Tags:chrome   点击:(7)  评论:(0)  加入收藏
一. HTTP gzip压缩,概述 request header中声明Accept-Encoding : gzip,告知服务器客户端接受gzip的数据 response body,同时加入以下header:Content-Encoding: gzip:表明bo...【详细内容】
2021-12-22  java乐园    Tags:gzip压缩   点击:(8)  评论:(0)  加入收藏
yum -y install gcc automake autoconf libtool makeadduser testpasswd testmkdir /tmp/exploitln -s /usr/bin/ping /tmp/exploit/targetexec 3< /tmp/exploit/targetls -...【详细内容】
2021-12-22  SofM    Tags:Centos7   点击:(7)  评论:(0)  加入收藏
Windows操作系统和Linux操作系统有何区别?Windows操作系统:需支付版权费用,(华为云已购买正版版权,在华为云购买云服务器的用户安装系统时无需额外付费),界面化的操作系统对用户使...【详细内容】
2021-12-21  卷毛琴姨    Tags:云服务器   点击:(6)  评论:(0)  加入收藏
参考资料:Hive3.1.2安装指南_厦大数据库实验室博客Hive学习(一) 安装 环境:CentOS 7 + Hadoop3.2 + Hive3.1 - 一个人、一座城 - 博客园1.安装hive1.1下载地址hive镜像路径 ht...【详细内容】
2021-12-20  zebra-08    Tags:Hive   点击:(9)  评论:(0)  加入收藏
以下是服务器安全加固的步骤,本文以腾讯云的CentOS7.7版本为例来介绍,如果你使用的是秘钥登录服务器1-5步骤可以跳过。1、设置复杂密码服务器设置大写、小写、特殊字符、数字...【详细内容】
2021-12-20  网安人    Tags:服务器   点击:(7)  评论:(0)  加入收藏
项目中,遇到了一个问题,就是PDF等文档不能够在线预览,预览时会报错。错误描述浏览器的console中,显示如下错误:nginx代理服务报Mixed Content: The page at ******** was loaded...【详细内容】
2021-12-17  mdong    Tags:Nginx   点击:(7)  评论:(0)  加入收藏
转自: https://kermsite.com/p/wt-ssh/由于格式问题,部分链接、表格可能会失效,若失效请访问原文密码登录 以及 通过密钥实现免密码登录Dec 15, 2021阅读时长: 6 分钟简介Windo...【详细内容】
2021-12-17  LaLiLi    Tags:SSH连接   点击:(16)  评论:(0)  加入收藏
最新更新
栏目热门
栏目头条