Spring Boot启动源码解析

new SpringApplication(primarySources).run(args)

  • 创建SpringApplicatioin
    getSpringFactoriesInstances 这个方法就是去spring.factories中找需要加载的对应的class类型

    • 保存一些信息
    • 判定当前应用的类型 ClassUtils 一般为 SERVLET
    • bootstrapRegistryInitializers:初始启动引导器 (List):去spring.factories文件中找org.springframework.boot.Bootstrapper
    • ApplicationContextInitializer(初始化器),去spring.factories中找ApplicationContextInitializer类型的
      • List<ApplicationContextInitializer<?>> initializers
    • ApplicationListener ,应用监听器。去spring.factories找ApplicationListener
      • List<ApplicationListener<?>> listeners
  • 运行SpringApplication

    • StopWatch
    • 记录应用的启动时间 stopWatch.start();
    • 创建引导上下文(context环境) createBootstrapContext()
      • 获取到所有之前的 bootstrapRegistryInitializers 挨个执行 initialize() 来完成对引导启动器上下文环境设置
    • 让当前应用进去headless 模式 java.awt.headless
    • 获取所有getRunListeners(运行时监听器) 【为了方便所有Listener进行时间感知
      • getSpringFactoriesInstances去spring.factories文件中找SpringApplicationRunListener
    • 遍历SpringApplicationRunListener 调用 starting 方法
      • 相当于通知所有感兴趣系统正在启动过程的人,项目正在starting
    • 保存命令行参数ApplicationArguments
    • 准备环境prepareEnvironment(), 执行完成后,所有的环境信息准备就绪
      • 返回或者创建一个基础环境信息,通过getOrCreateEnvironment(),得到ApplicationServletEnvironment对象
      • 配置环境信息configureEnvironment()
        • 读取外部配置源 configurePropertySources()
        • 激活profile环境内容 configureProfiles()
        • 读取所有的配置源的配置属性值
      • 将配置环境绑定 ConfigurationPropertySources.attach(environment)
      • 监听器调用 listeners.environmentPrepared() 通知所有的监听器当前环境准备完成
      • 将当前环境信息设置到DefaultPropertiesPropertySource的最后 调用 DefaultPropertiesPropertySource.moveToEnd(environment);
      • 将环境绑定到 SpringApplication,调用 bindToSpringApplication(environment);
    • 配置需要忽略的环境信息 configureIgnoreBeanInfo(environment);
    • 打印banner printBanner(environment);
    • 创建IOC容器createApplicationContext()
      • 根据当前项目类型(Servlet)进行创建
      • 当前会创建AnnotationConfigServletWebServerApplicationContext
    • 保存startUp context.setApplicationStartup(this.applicationStartup);
    • 准备ApplicationContext (IOC容器)的信息 prepareContext()
      • 保存环境信息 context.setEnvironment(environment);
      • IOC容器的后置处理流程 postProcessApplicationContext()
      • 应用初始化器,applyInitializers()
        • 通过 getInitializers() 获取所有的ApplicationContextInitializer遍历所有的 ApplicationContextInitializer调用其initialize() 来对IOC容器进行初始化的扩展功能
      • 遍历所有的Listener,调用 listeners.contextPrepared(context); EventPublishingRunListener(事件派发的Listener),通知所有的监听器contextPrepared(IOC容器开始加载)
      • 关闭引导上下文的环境 bootstrapContext.close(context);
      • 获取bean工厂 context.getBeanFactory();
      • 注册参数单实例 registerSingleton(“springApplicationArguments”, applicationArguments);
      • 注册banner组件 beanFactory.registerSingleton(“springBootBanner”, printedBanner);
      • 所有的监听器调用 listener.contextLoaded(context),通知所有的监听器 contextLoaded***(IOC容器已经加载了)***
    • 刷新IOC容器 refreshContext(context);
      • 创建容器中的所有组件 和 spring底层呼应
    • 容器刷新完成后工作 afterRefresh(context, applicationArguments);
    • 记录应用启动完成时间 stopWatch.stop();
    • 所有监听器调用 listeners.started(context); 通知所有监听器当前项目已经启动
    • 调用所有的runners ,callRunners(context, applicationArguments);
      • 获取容器中的 ApplicationRunner
      • 获取容器中的CommandLineRunner
      • 合并所有runner,并且按照@Order进行排序 AnnotationAwareOrderComparator.sort(runners);
      • 遍历所有的runner,调用run方法
    • 如果以上有异常 handleRunFailure(context, ex, null);
      • 调用Listener的listeners.failed(context, exception); 通知所有监听器启动失败
    • 调用所有监听器的listeners.running(context); 方法 通知所有的监听器项目进入 running(运行)状态
    • running如果有问题,继续通知failed handleRunFailure(context, ex, null);
      • 调用Listener的listeners.failed(context, exception); 通知所有监听器运行失败
@FunctionalInterface
public interface BootstrapRegistryInitializer {

   /**
    * Initialize the given {@link BootstrapRegistry} with any required registrations.
    * @param registry the registry to initialize
    */
   void initialize(BootstrapRegistry registry);

}
@FunctionalInterface
public interface ApplicationRunner {

   /**
    * Callback used to run the bean.
    * @param args incoming application arguments
    * @throws Exception on error
    */
   void run(ApplicationArguments args) throws Exception;

}
@FunctionalInterface
public interface CommandLineRunner {

   /**
    * Callback used to run the bean.
    * @param args incoming main method arguments
    * @throws Exception on error
    */
   void run(String... args) throws Exception;

}

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

龘龍龙

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值