SpringApplication.run()方法传入了主配置类,打上断点开始Debug启动

step into 进入,首先,它 new 了一个class,传入了我们的主配置类

直接进入 run 方法

在run方法里边,可以看到它做了两件事:第一,创建 SpringApplication;第二,运行SpringApplication
所以,接下来就是看这两步中到底干了什么?
首先,调用有参构造器进行初始化,保存一些信息

我们主要看一下红色框中的东西





我们 step into ,进入 run() 方法

1、StopWatch 记录应用的启动时间
2、创建引导上下文(Context环境)createBootstrapContext()

获取到所有之前的 bootstrappers 挨个执行 intitialize() 来完成对引导启动器上下文环境设置


getSpringFactoriesInstances 去spring.factories找 SpringApplicationRunListener.

相当于通知所有对系统启动过程感兴趣的人,项目正在 starting。

6、保存命令行参数;ApplicationArguments
7、准备环境 prepareEnvironment();

返回或者创建基础环境信息对象。StandardServletEnvironment

配置环境信息对象。

绑定环境信息
监听器调用 listener.environmentPrepared();通知所有的监听器当前环境准备完成

下边还有一些环境信息的获取和绑定,就不一一看了,直到 prepareEnvironment()执行完毕,所有的环境信息就配置好了……
8、创建IOC容器(createApplicationContext())


9、准备 ApplicationContext IOC容器的基本信息 prepareContext()

保存环境信息 —> context.setEnvironment(environment);
IOC容器的后置处理流程 —> this.postProcessApplicationContext(context);
应用初始化器 —> applyInitializers
遍历所有的 ApplicationContextInitializer 。调用 initialize() 来对ioc容器进行初始化扩展功能

遍历所有的 listener 调用 contextPrepared。EventPublishRunListenr;通知所有的监听器contextPrepared

所有的监听器 调用 contextLoaded。通知所有的监听器 contextLoaded;

到这里,IOC的前置准备工作就完成了
10、刷新IOC容器。refreshContext

11、容器刷新完成后工作?afterRefresh,到这里就启动完成了
12、所有监听器 调用 listeners.started(context); 通知所有的监听器 started

13、调用所有runners;callRunners()

14、如果以上有异常,调用Listener 的 failed

15、调用所有监听器的 running 方法 listeners.running(context); 通知所有的监听器 running
16、running如果有问题。继续通知 failed 。调用所有 Listener 的 failed;通知所有的监听器 failed
到这里,SpringBoot的完整启动过程分析就完成了
OVER(∩_∩)O~