一、JVM、Tomcat、Spring Bean 容器三者的关系
这三者是 层层嵌套、职责分明 的关系,可以理解为 "容器中的容器":

-
JVM(Java Virtual Machine)
角色:最底层的运行环境。
职责:
加载 .class 字节码
管理内存(堆、栈、方法区等)
执行垃圾回收(GC)
提供线程、安全、性能等基础能力
特点:一个操作系统进程(java 进程),运行一个或多个 Java 应用(但通常一个 JVM 只跑一个 Tomcat 实例)。
✅ 没有 JVM,Java 程序根本无法运行。
-
Tomcat(Servlet 容器 / Web 容器)
角色:运行在 JVM 之上的 Web 应用服务器。
职责:
监听 HTTP 请求(如 8080 端口)
解析 HTTP 协议,封装成 HttpServletRequest / HttpServletResponse
根据 URL 路由到对应的 Servlet
管理 Web 应用的生命周期(加载、启动、销毁)
提供 JSP 编译、会话管理、安全认证等 Web 功能
关键点:
Tomcat 本身是用 Java 写的,所以它 运行在 JVM 中。
它负责 加载你的 Web 应用(WAR/目录),并初始化其中的 Servlet、Filter、Listener。
✅ Tomcat 是 Web 应用和 JVM 之间的桥梁。
-
Spring Bean 容器(ApplicationContext)
角色:运行在 Tomcat 内部的 应用级 IoC 容器。
职责:
管理你代码中的 Bean(如 @Service, @Component, @Repository)
实现依赖注入(DI)、AOP、事务管理等 Spring 特性
通常由 ContextLoaderListener 或 DispatcherServlet 在 Web 应用启动时初始化
关键点:
Spring 容器 不是 Tomcat 的一部分,而是 你的应用代码引入的框架。
它由 Tomcat 在加载 Web 应用时 自动启动(通过 web.xml 或注解)。
一个 Web 应用可以有 多个 Spring 容器(如 Root Context + Web Context)。
✅ Spring 容器是你业务逻辑的"管家",由 Tomcat 帮你启动。
🔄 三者协作流程(以一次 HTTP 请求为例)
- JVM 启动 → 加载 Tomcat 的 .class 文件
- Tomcat 启动 → 读取 server.xml,监听 8080 端口
- 部署你的 WAR 包 → Tomcat 加载你的 Web 应用
- Tomcat 初始化 Spring → 通过 ContextLoaderListener 创建 ApplicationContext
- Spring 扫描 Bean → 创建并管理所有 @Service、@Controller 等对象
- 用户访问 /user/1:
Tomcat 接收请求,交给 DispatcherServlet
DispatcherServlet 从 Spring 容器 中获取 UserController Bean
调用方法,返回结果
Tomcat 将结果写回 HTTP 响应
💡 总结一句话:
JVM 运行 Tomcat,Tomcat 运行 Web 应用,Web 应用启动 Spring 容器,Spring 容器管理你的业务 Bean。