第十章 SpringBoot 启动流程

1 创建SpringApplication

  • 保存部分信息
  • ClassUtils判定当前应用的类型,通常为Servlet
  • Bootstrapper:初始启动引导器,去spring.factories文件中找Bootstrapper
  • ApplicationContextInitializer:去spring.factories找ApplicationContextInitializer
  • ApplicationListener :应用监听器,去spring.factories找ApplicationListener

2 运行SpringApplication

  • StopWatch(监听整个应用程序启动停止的监听器)
  • 记录应用的启动时间
  • 创建引导上下文(Context环境)createBootstrapContext()
  • 获取到所有之前的 bootstrappers 挨个执行 intitialize() 来完成对引导启动器上下文环境设置
  • 让当前应用进入headless模式,java.awt.headless
  • 获取所有RunListener(运行监听器),方便所有Listener进行事件感知
    • getSpringFactoriesInstances 去spring.factories找SpringApplicationRunListener
  • 遍历 SpringApplicationRunListener 调用 starting 方法
    • 通知所有对系统正在启动过程感兴趣的人,项目正在 starting
  • 保存命令行参数,ApplicationArguments
  • 准备环境 prepareEnvironment()
    • 返回或者创建基础环境信息对象,StandardServletEnvironment
    • 配置环境信息对象
      • 读取所有的配置源的配置属性值
    • 绑定环境信息
    • 监听器调用 listener.environmentPrepared(),通知所有的监听器当前环境准备完成
  • 创建IOC容器(createApplicationContext())
    • 根据项目类型(Servlet)创建容器
    • 当前会创建AnnotationConfigServletWebServerApplicationContext
  • 准备ApplicationContext IOC容器的基本信息,prepareContext()
    • 保存环境信息
    • IOC容器的后置处理流程
    • 应用初始化器,applyInitializers
      • 遍历所有的ApplicationContextInitializer,调用initialize,来对ioc容器进行初始化扩展功能
      • 遍历所有的 listener(例如EventPublishRunListenr)调用contextPrepared,通知所有的监听器contextPrepared
      • 遍历所有的 listener调用contextLoaded,通知所有的监听器contextLoaded
  • 刷新IOC容器,refreshContext
    • 创建容器中的所有组件(Spring注解)
  • 容器刷新完成后工作,afterRefresh
  • 所有监听器调用listener.started(context),通知所有的监听器started
  • 调用所有runners,callRunners()
    • 获取容器中的ApplicationRunner
    • 获取容器中的CommandLineRunner
    • 合并所有runner并且按照@Order进行排序
    • 遍历所有的runner,调用 run方法
  • 如果以上有异常,调用Listener的failed方法
  • 所有监听器调用listeners.running(context),通知所有的监听器running
  • running如果有问题,继续通知failed,调用所有Listener的failed方法,通知所有的监听器failed

3 相关组件

  • Application Events and Listeners
    • ApplicationContextInitializer
    • ApplicationListener
    • SpringApplicationRunListener
  • ApplicationRunner 与 CommandLineRunner
posted @ 2022-02-07 22:32  hunter-w  阅读(23)  评论(0编辑  收藏  举报