下图是对于Tomcat处理请求内部的流转过程.也描述了Tomcat组件的静态关系.
如果让一个系统能够对外提供服务,需要创建,组装并启动这些组件,在停止的时候,需要释放资源,销毁组件,这个过程都是动态的,所以Tomcat需要动态管理这些组件的生命周期.
在Tomcat的启动过程中,每个组件都要经历 创建
, 初始化
, 启动
这几个过程,而这几个状态的转变都是固定的,但是具体组件的初始化逻辑和启动方式都不一样,所以Tomcat把组件的生命周期方法抽象到 LifeCycle
接口,让每个具体的组件去实现接口的方法.
可以看到红框内的方法就是对组件生命周期的抽象
为了解耦组件,所以LifeCycle中的方法都是由父组件进行调用,如果要对子组件新增逻辑,就需要用到组件的状态监听.
这里用到了观察者模式.上图中的 Listener
相关方法就是监听组件状态变化的方法. LifecycleStats
枚举类定义了组件的所有状态
在 LifeCycle
依赖关系中,可以看到有一个实现类 LifeCycleBase
,实现了 LifeCycle
接口的所有方法,定义了相应的抽象方法交给子类实现,这是经典的 模板设计
模式.