Spring Boot 启动流程

Spring Boot 启动流程大致分为以下几个步骤:

  1. 加载 Spring 应用上下文: Spring Boot 在启动时会加载 应用程序的配置文件 (如 application.properties 或 application.yml),然后基于这些配置创建 Spring 应用上下文(ApplicationContext)。

  2. 扫描注册组件: Spring Boot 会扫描应用程序中的所有组件 (如控制器、服务、配置类等),并注册到应用上下文中。

  3. 自动配置: Spring Boot 会根据 classpath 中的依赖和配置,自动配置 应用程序所需的 bean,例如数据源、事务管理器、Web 容器等。

  4. 启动内嵌容器: Spring Boot 内置了常用的 Servlet 容器(如 Tomcat、Jetty、Undertow),在启动过程中会根据配置选择 合适的容器 ,并将应用程序部署到容器中。

  5. 运行应用程序: 容器启动后,Spring Boot 会执行应用程序的启动逻辑,包括执行 CommandLineRunner 或**ApplicationRunner** 接口的实现类中的 run 方法,以及处理 HTTP 请求等。

  6. **加载应用程序监听器和事件:**Spring Boot 支持应用程序监听器和事件机制,可以在应用程序启动、停止、失败等事件发生时执行自定义逻辑。

  7. **应用程序初始化:**在启动过程中,Spring Boot 还会执行一些初始化操作,例如加载配置、注册拦截器、配置消息转换器等。

相关推荐
雪隐14 小时前
个人电脑玩AI-09让5060 Ti给你打工——让 AI 读懂你的资料
人工智能·后端
小满zs14 小时前
Go语言第一章(入门)
后端·go
用户67570498850214 小时前
Kafka 太重?试试 NSQ:一个优雅到极致的消息队列
后端·go
铁皮饭盒15 小时前
S3已成为文件存储标准,阿里/腾讯/华为云都支持,Bun率先原生支持
前端·javascript·后端
洛卡卡了15 小时前
Claude Code Hook,当 CLAUDE.md 规则不生效时,我们还需要强制拦截机制
后端·agent·claude
用户67570498850215 小时前
RabbitMQ 太重,Kafka 太复杂?Go 开发者:Asynq分布式任务队列就刚刚好
后端·go
AlbertLuo15 小时前
CodeMirror使用: 编写一个在线编辑HTML、JS、CSS文件,网页的模板页面-初实现
后端
SamDeepThinking15 小时前
裁掉那个差程序员后,给你看团队里高手的代码:这个习惯,希望你有
java·后端·程序员
Oneslide16 小时前
windows 11远程桌面连Ubuntu GNOME 远程登录频繁断开
后端
朕瞧着你甚好16 小时前
技术雷达 & Java 集成评估报告 — Apache Tika 3.3.1
java·ai编程