系列文章目录
第一章 HTTP协议必知必会详解
第二章 一文读懂 Servlet 规范与 Servlet 容器加粗样式
第三章 深入拆解 Servlet 实战:纯手工打造与运行
第四章 深入拆解 Tomcat 系统架构:连接器如何设计
第五章 深入拆解Tomcat架构:多层容器设计原理
第六章 深入拆解 Tomcat 架构:一键启停与生命周期设计
文章目录
前言
Tomcat 启动全流程,介绍Bootstrap、Catalina、Server、Service、Engine五大 "高层" 组件的管理职责,讲解启动顺序、关闭钩子、数组 / HashMap 存储子组件、MapperListener 热部署等核心设计,并说明组件按依赖关系有序启停,加锁保障并发安全。
一、思维导图

二、Tomcat 完整启动流程(5 步)
- 执行 startup.sh:启动 JVM,运行启动入口类Bootstrap。
- Bootstrap:初始化 Tomcat 类加载器,实例化Catalina。
- Catalina:解析server.xml,创建所有组件,调用Server.start()。
- Server:管理所有 Service,调用Service.start()。
- Service:启动Engine容器 → MapperListener → Connector连接器。
三、五大高层组件职责
| 组件 | 核心定位 | 关键功能 |
|---|---|---|
| Bootstrap | 启动入口 | 初始化类加载器,创建 Catalina 实例 |
| Catalina | 总调度器 | 解析配置、创建组件、注册关闭钩子、优雅停机 |
| Server | 顶层管理者 | 管理多个 Service、监听8005 端口关闭命令 |
| Service | 业务单元 | 管理 1 个 Engine + 多个 Connector、维护路由 Mapper |
| Engine | 顶层容器 | 接收请求并转发给对应 Host 子容器 |
四、关键设计细节
- 组件存储结构
Server使用动态数组保存 Service,添加时扩容复制,节省内存。
ContainerBase使用HashMap保存子容器,支持快速查找。 - 启动顺序(强依赖)
先启动Engine(容器)
再启动MapperListener(热部署监听)
最后启动Connector(网络通信) - 关闭钩子(CatalinaShutdownHook)
向 JVM 注册关闭线程,JVM 退出前执行Server.stop(),释放全部资源。 - Server 关闭端口
await()方法监听8005端口,收到SHUTDOWN指令则停止 Tomcat。 - 热部署支持
MapperListener监听容器变化,自动更新Mapper路由映射表。 - 线程安全
对组件启动 / 添加操作加锁,防止并发修改导致数据异常。
五、核心设计思想
- 按依赖关系控制启停顺序,避免启动失败。
- 用合适的数据结构管理子组件,平衡内存与效率。
- 通过钩子 + 监听实现优雅停止与热部署。
六、常见问题
- 问题 1(流程侧重) :Tomcat 从执行 startup.sh 到完全启动的完整链路是什么?
答案:startup.sh → JVM 启动 Bootstrap → 初始化类加载器并创建 Catalina → Catalina 解析 server.xml 创建 Server → Server 启动所有 Service → Service 依次启动 Engine、MapperListener、Connector。 - 问题 2(组件侧重) :Service 组件内部为什么要按 Engine → MapperListener → Connector 的顺序启动?
答案:因为Engine 是容器核心,必须先启动;MapperListener 依赖容器才能监听变化;Connector 对外提供服务,必须等内部组件全部就绪后再启动,保证服务可用且不报错。 - 问题 3(机制侧重) :Tomcat 的关闭钩子是什么?作用是什么?
答案:关闭钩子是CatalinaShutdownHook 线程;作用是在 JVM 关闭时被自动执行,调用Server.stop()统一停止所有组件、释放资源,实现优雅停机,避免资源泄漏。