窥探Tomcat整体架构,server.xml常用配置解析( 二 )


2.2 GlobalNamingResourcesGlobalNamingResources全局命名资源,通过JNDI提供统一的命名对象访问接口 。而JNDI(JAVA Naming and Directory Interface)是一个比较老旧的技术,在历史遗留的企业级应用中可能还在用,诸如获取一个数据库连接资源、自定义配置等,这种强耦合在启动配置文件里的方式已经不适用现在轻量级的应用和分布式服务了 。(后续可以单独研究下,这里了解即可 。)
2.3 监听SHUTDOWN命令Tomcat启动时,主线程做完所有启动工作后,会进入循环等待SHUTDOWN的状态 。如果接收到SHUTDOWN,结束循环调用Tomcat停止销毁接口 。
实现方式很简单,单独给主线程建立一个socket连接,时刻监听某个端口(默认8005),是否发来SHUTDOWN命令 。
2.4 定时触发自动部署周期性事件Server启动时,会开启两个定时任务,一个是每10秒触发一次自动部署事件,而这个定时任务可能会因为自动部署的检查和部署过程中出现异常导致该定时任务停止,所以就有了另一个定时任务每1分钟检查一次自动部署定时任务是否有在正常运行,没有就重新设置 。(自动部署是Host的工作,在Host的生命周期监听器HostConfig中监听执行)
三、服务抽象ServiceService默认标准实现是
org.apache.catalina.core.StandardService,如果在Server中配置了多个Service,name必须唯一,不可重复 。
Service包含的组件有Executor、Connector、Engine,还有一个Mapper组件没有在配置中体现,一般也不需要配置 。
3.1 共享线程池ExecutorService中可以定义一些线程池,供Connector和其他组件使用 。Tomcat没有另起炉灶实现自己的线程池,而是在JUC的ThreadPoolExecutor基础上做了定制化改造,默认标准实现是
org.apache.catalina.core.StandardThreadExecutor 。
Executor可配置项如下:

窥探Tomcat整体架构,server.xml常用配置解析

文章插图
 
注意:
如果指定Executor的实现是StandardThreadExecutor,那么prestartminSpareThreads无论是true还是false,都会预先创建minSpareThreads个核心工作线程 。
3.2 连接器ConnectorConnector是Service的门户,一个Service可以有多个Connector 。Connector定义了多种连接协议,配置较为复杂,现仅提供常见配置说明:
窥探Tomcat整体架构,server.xml常用配置解析

文章插图
 
注意:
Tomcat10.0.6中NioEndpoint已经不能配置Poller线程和acceptor线程的个数,默认都是一个,同时AprEndpoint也标注为不建议使用,所以关于APR的配置也可以不用深入了解 。后面会详细研究Connector的内部实现,到时讲解其他与源码相关的配置项 。
窥探Tomcat整体架构,server.xml常用配置解析

文章插图
 
3.3 容器引擎EngineEngine是Servlet容器最顶端的管理者,负责处理对应Service中所有请求,包含多个Host和其他组件 。默认标准实现是
org.apache.catalina.core.StandardEngine 。Engine以及其子容器都继承自ContainerBase,都有些相似的组件,如AccessLog、Pipeline、Cluster、Realm、Log、LifecycleListener、ContainerListener等 。
Engine、Host、Context都有一个同名前缀的LifecycleListener,如Engine的是EngineConfig,Host的是HostConfig,Context是ContextConfig,分别监听自己感兴趣的生命周期事件,如EngineConfig就是在Engine启动停止时输出一些日志 。
对于Engine节点可选配置有如下几个:
窥探Tomcat整体架构,server.xml常用配置解析

文章插图
 
注意:
  • Engine即其子容器Host、Context、Wrapper都可以设置backgroundProcessorDelay这个参数,都可以有自己的后台线程来延迟backgroundProcessorDelay时长周期性处理一些事情 。如果backgroundProcessorDelay<=0则不会创建私有的后台线程,默认Engine中这个参数是10,其他子容器是-1,所以一般情况子容器需要后台处理的事情,都交由Engine启动的后台线程周期性延迟处理 。
  • 上层容器启动停止下层容器时,会用一个线程池来做异步处理 。
3.4 URI映射器MapperService中Mapper组件主要提供给Connector和Context使用,Connector中处理完连接后需要将请求信息交给对应的Host处理,可以通过Mapper的解析找到Host;Context通过Mapper找到对应的Servlet(Wrapper)处理业务 。
Mapper还有一个对应的生命周期监听器MapperListener,其主要监听容器启动后,将容器注册到Mapper的关系中,建立一个树状结构 。容器停止后做一些销毁、反注册操作 。
(详细的Mapper原理后面会单独出文章讲解)
四、虚拟主机HostHost是Engine的子容器,默认标准实现是


推荐阅读