Tomcat整体架构简析

一、Tomcat 容器的总体架构

Tomcat 容器主要用来提供servlet运行环境,对其生命期进行管理,从而提供各种服务service。

Tomcat 的两大核心组件:Connector和Container共同组成了各种服务。如下图所示:

Tomcat整体架构简析_第1张图片

Tomcat总体架构分析图

Connector

connector主要用于监听各种协议的发送的请求,并创建出请求响应的Request和Response对象。

之后创建一个处理该请求的线程,传入request和response对象,并提交到container中,等待container执行。

另外Connector有多种实现,一个Tomcat容器中通常具有一个Connector组成的集合。

Container

Container包含一个责任链设计模式,层层调用最终通过Servlet的包装wrapper实现请求的调用。

Service与Server

Service是一个接口,负责管理Connector和Container。其标准实现类StandardService由Connector和Container组成。

Service接口同时也继承了LifeCycle接口,方便对tomcat中各个组件的整体生命周期进行管理。

Server接口负责管理Tomcat中的Service集合。通过Server接口,tomcat实现管理和运行service,对外部暴露应用。

二、Connector详解

Connector的重要作用在于:接受请求,封装请求和相应对象,创建线程任务交给Container处理

Connector的信息可以在server.xml配置文件中看到。明显的可以看到8080是TCP连接端口,8009是Apache服务器和tomcat

通信使用的端口等。

Connector在server start时进行初始化,之后等待请求到来,通过httpProcessor包装线程和请求对象,交给container处理。

流程如下图所示:

Tomcat整体架构简析_第2张图片

请求处理时序图

三、Container详解

Tomcat容器中,Container实际上是用责任链设计模式。Container是所有容器的父接口,任何一种容器实现。

它具有四个子容器:Engine,Host,Context,Wrapper;四者成父子关系

Engine是整个tomcat容器的完整servlet引擎,通过它在最上层调用;

Host代表Engine中的一个虚拟机,这个Host的作用在于运行多个应用并区分它们(Context);

Context是Servlet的基本运行环境,它维护了servlet与url、绝对路径的关系等。每个应用就是一个Context;

Wrapper是对Servlet原生对象的包装,Wrapper便于对LifeCycle生命周期进行管理

四、lifecycle接口与生命周期

上面已经讲到,Tomcat中几乎所有的接口都实现了LifeCycle接口,这也使得,整个tomcat的启动和关闭过程中,可以直接

通过责任链设计模式Lifecycle接口实现对所有对象的生命周期管理。同时可以在各个子接口中实现自己的功能呢。

例如在server 的Start过程中可以解析默认的server.xml文件,而container的start过程中会解析web.xml等。

在stop的时候,container又可以处理服务器缓存的session。将他们持久化 到磁盘上。

你可能感兴趣的:(Tomcat整体架构简析)