以下回答来自chatGPT
Server组件和Service组件是Tomcat核心组件中最外层的两个组件。
Server组件是Tomcat运行实例的抽象,Server组件包含若干Listener组件、GlobalNamingResources组件和若干Service组件。
Service组件包含若干Connector组件和Executor组件。
server.xml配置文件。
主要作用是:
Tomcat在运行中是存在很多阶段的,也就是Tomcat会处于不同的生命周期中。而Server会在某些阶段执行某些逻辑,提供了监听器机制。(这里的意思感觉是如果我能控制的了这个控制器,是不是就可以去做一些不死的操作。)
下面是一些监听器。
Server组件包含了一个全局命名资源,提供的命名对象通过ResourceLink可以给所有Web应用使用。
Tomcat启动的时候会将Server.xml配置文件里面GlobalNamingResources节点通过Digester框架映射到一个NamingResources对象。
Server会另外开放一个端口用于监听关闭命令,默认为8005.
Tomcat中有两类线程,一类是主线程,另外一类是daemon线程。当Tomcat启动的时候,Server将被主线程执行,完成所有启动工作。 然后主线程相当于是一直在等结束。
Service组件是若干Connector组件和Executor组件组合而成。 不同的端口对应不同的Connector。 Executor组件在Service抽象层面提供了线程池,让Service的组件可以公用线程池。
Tomcat各个组件:
服务器,Tomcat服务器,一个Tomcat只有一个Server组件;
业务层,是Server下最大的子容器,一个Server可以包含多个Service组件;
Tomcat实例化的是StandardServer,Server同样实现了Lifecycle接口
StandardServer实例化初始化了globalNamingResources,具体干嘛的还不清楚,和JNDI相关;Catalina的load方法的initNaming方法,决定了这里会添加第一个监听器NamingContextListener,这个LifecycleListener暂时不需要了解,JNDI上下文相关的. 其次的LifecycleListener是通过server.xml读取.
也就是说StandardServer实例化之后共有六个LifecycleListener,当然这些LifecycleListener具体作用暂时还不用知道,看名字简单了解下打印日志、内存防止泄露等等.
只要继承了LifecycleMBeanBase的类,调用父类的initInternal方法,目的是为了将该组件注册到JMX管理,JMX的作用暂时不是现在记录的重点。加载classLoader,也就是commonLoader,指向catalina.home/lib,对下面的jar文件进行校验;最后就是遍历service组件,分别调用init方法初始化.
上图是按照StandardService的init方法简单绘制的。在记录Service初始化流程之前,介绍下StandardService实例化的过程。
先查看下server.xml对于Service元素的定义,以Tomcat中标准的server.xml为例. 下就以这样三个子元素为例,
下面就是StandardService初始化具体流程,super.initInternal方法JMX注册; 初始化按照顺序 container—>Executor—>mapperListener---->Connector的顺序
连接器,Service的子容器,一个Service可以有多个Connector连接器,作用体现在对外,接收客户端请求,HTTP、TCP等;
Service核心组件,通常有Engine、Host、Context、Wrapper,作用是将客户端请求处理;
总而言之,Tomcat的初始化工作,主要是Server初始化,而Server初始化主要看Service的初始化,Service的初始化工作主要是 initInternal方法, 又由其他组件 Container、(Executor)、mapperListener、Connector的初始化来完成。 上面总结了StandardServer、StandardService的实例化、初始化流程。