回顾Tomcat处理请求
下图是对于Tomcat处理请求内部的流转过程.也描述了Tomcat组件的静态关系.
如果让一个系统能够对外提供服务,需要创建,组装并启动这些组件,在停止的时候,需要释放资源,销毁组件,这个过程都是动态的,所以Tomcat需要动态管理这些组件的生命周期.
Tomcat的LifeCycle接口
在Tomcat的启动过程中,每个组件都要经历创建
,初始化
,启动
这几个过程,而这几个状态的转变都是固定的,但是具体组件的初始化逻辑和启动方式都不一样,所以Tomcat把组件的生命周期方法抽象到LifeCycle
接口,让每个具体的组件去实现接口的方法.
可以看到红框内的方法就是对组件生命周期的抽象
LifeCycle的监听事件
为了解耦组件,所以LifeCycle中的方法都是由父组件进行调用,如果要对子组件新增逻辑,就需要用到组件的状态监听.
这里用到了观察者模式.上图中的
Listener
相关方法就是监听组件状态变化的方法.LifecycleStats
枚举类定义了组件的所有状态
在LifeCycle
依赖关系中,可以看到有一个实现类LifeCycleBase
,实现了LifeCycle
接口的所有方法,定义了相应的抽象方法交给子类实现,这是经典的模板设计
模式.
LifeCycleBase的init方法
可以看到初始化方法是synchronized
修饰的,证明不能多线程进行组件的创建.
- 1.检查状态
- 2.修改状态,触发
INITIALIZING
事件监听
状态变化会通知所有的观察者
- 3.调用子类的初始化方法
- 4.修改状态,触发
INITIALIZED
事件监听
组件监听器注册方法
- Tomcat自定义的监听器,这些监听器是父组件在创建子组件的过程中注册到子组件的.例如MemoryLeakTracingListener,用来检测Context容器中的内存泄漏,这个监听器在Host容器创建Context容器时注册到Context中的.
具体位置在StandardHost#addChild方法
- 在server.xml定义监听器,Tomcat在启动时会解析server.xml,创建监听器并注册到容器组件.
ContainerBase的公共逻辑
- 1.容器的创建/初始化/销毁
- 2.容器添加/删除子容器