深入拆解Tomcat&Jetty(六)

759 阅读2分钟

回顾Tomcat处理请求

下图是对于Tomcat处理请求内部的流转过程.也描述了Tomcat组件的静态关系.

如果让一个系统能够对外提供服务,需要创建,组装并启动这些组件,在停止的时候,需要释放资源,销毁组件,这个过程都是动态的,所以Tomcat需要动态管理这些组件的生命周期.

Tomcat的LifeCycle接口

在Tomcat的启动过程中,每个组件都要经历创建,初始化,启动这几个过程,而这几个状态的转变都是固定的,但是具体组件的初始化逻辑和启动方式都不一样,所以Tomcat把组件的生命周期方法抽象到LifeCycle接口,让每个具体的组件去实现接口的方法.

可以看到红框内的方法就是对组件生命周期的抽象

LifeCycle的监听事件

为了解耦组件,所以LifeCycle中的方法都是由父组件进行调用,如果要对子组件新增逻辑,就需要用到组件的状态监听.

这里用到了观察者模式.上图中的Listener相关方法就是监听组件状态变化的方法.LifecycleStats枚举类定义了组件的所有状态

LifeState定义的组件状态

LifeCycle依赖关系

LifeCycle依赖关系中,可以看到有一个实现类LifeCycleBase,实现了LifeCycle接口的所有方法,定义了相应的抽象方法交给子类实现,这是经典的模板设计模式.

LifeCycleBase的init方法

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.容器添加/删除子容器