一、Tomcat 容器的总体架构
Tomcat 容器主要用来提供servlet运行环境,对其生命期进行管理,从而提供各种服务service。
Tomcat 的两大核心组件:Connector和Container共同组成了各种服务。如下图所示:
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处理。
流程如下图所示:
请求处理时序图
三、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。将他们持久化 到磁盘上。