springboot执行流程
构造方法初始化,创建一个新的实例,这个应用程序的上下文要从指定的来源加载bean
public SpringApplication(ResourceLoaderresourceLoader,Class<?>...primarySources){
this.sources=newLinkedHashSet();
this.bannerMode=Mode.CONSOLE;
this.logStartupInfo=true;
this.addCommandLineProperties=true;
this.headless=true;
this.registerShutdownHook=true;
this.additionalProfiles=newHashSet();
初始化资源加载器,默认为null
this.resourceLoader=resourceLoader;
断言要加载的资源类不能为null否则报错
Assert.notNull(primarySources,"Primary Sources must not be null");
初始化主要加载资源并去重
this.primarySources=newLinkedHashSet(Arrays.asList(primarySources));
判断当前应用程序的类型 NONE/SERVLET/REACTIVE
this.webApplicationType=this.deduceWebApplicationType();
加载所有的初始化容器,设置应用上下文初始化器,从"META-INF/spring.factories"读取ApplicationContextInitializer类的实例名称集合并去重,并进行set去重。(一共5个)
this.setInitializers(this.getSpringFactoriesInstances(ApplicationContextInitializer.class));
设置监听器,从"META-INF/spring.factories"读取ApplicationListener类的实例名称集合并去重,并进行set去重。(一共10个)
this.setListeners(this.getSpringFactoriesInstances(ApplicationListener.class));
推断主入口应用类,通过当前调用栈,获取Main方法所在类,并赋值给mainApplicationClass
this.mainApplicationClass=this.deduceMainApplicationClass();
}
启动流程
springboot启动的运行方法,可以看到主要是各种运行环境的准备工作
public ConfigurableApplicationContext run(String...args){
创建并启动计时监控类
设置当前任务的id和启动的时间,方便后续的时候进行计时的操作
StopWatch stopWatch=new StopWatch();
stopWatch.start();
初始化上下文
初始化异常报告集合
ConfigurableApplicationContext context=null;
Collection<SpringBootExceptionReporter> exceptionReporters=new ArrayList();
设置系统属性“java.awt.headless”
默认为true,用于运行headless服务器,进行简单的图像处理,多用于在缺少显示屏、键盘或者鼠标时的系统配置,很多监控工具如jconsole 需要将该值设置为true
this.configureHeadlessProperty();
注册linsteners,创建所有spring运行监听器并发布应用启动事件,简单说的话就是获取SpringApplicationRunListener类型的实例(EventPublishingRunListener对象),并封装进SpringApplicationRunListeners对象,然后返回这个SpringApplicationRunListeners对象。说的再简单点,getRunListeners就是准备好了运行时监听器EventPublishingRunListener。
记载spring.factoris文件中的你内容
获取文件中对应类的全路径
根据反射得到具体的实体类对象
生成对应的对象之后再返回给调用者
SpringApplicationRunListeners listeners=this.getRunListeners(args);
每次监听器在实际做操作的时候都会执行listeners.starting()
this.initialMulticaster.multicastEvent
匹配不同类型的事件,然后从所有的监听器中把不符合条件的监听给过滤掉
符合条件的监听器会循环执行具体的自己的处理逻辑
listeners.starting(); try{
初始化默认参数应用类
加载命令行的参数值,解析在命令行中通过--key=value输入的属性值,封装到ApplicationArguments对象中
ApplicationArguments applicationArguments=new DefaultApplicationArguments(args);
根据运行监听器和应用参数来准备spring环境
ConfigurableEnvironment environment=this.prepareEnvironment(listeners,applicationArguments);
设置系统属性,保证某些bean不会添加到准备的环境中(设置忽略的参数)
this.configureIgnoreBeanInfo(environment);
创建banner打印类
Banner printedBanner=this.printBanner(environment);
创建应用上下文对象,根据当前应用类型选择创建什么类型的上下文 servlet,reactive,none
context=this.createApplicationContext();
设置异常报告对象,用来支持报告关于启动的错误
this.getSpringFactoriesInstances(SpringBootExceptionReporter.class,newClass[]{ConfigurableApplicationContext.class},context);
准备当前上下文对象,包含一个关键操作,将启动类注入容器,为后续开启自动化提供基础
设置初始化进行执行,向beanfactory中注入了三个postprocessor的对象,后续在自动装配的时候会用到applyInitializers(context);
listeners.contextPrepared(context);
加载很多资源配置,自动装配在此环节完成load(context, sources.toArray(new Object[0]));
listeners.contextLoaded(context);
this.prepareContext(context,environment,listeners,applicationArguments,printedBanner);
刷新应用上下文
this.refreshContext(context);
应用上下文刷新后置操作做一些扩展功能
this.afterRefresh(context,applicationArguments);
计时结束,并打印程序所用时长
stopWatch.stop();
输出日志,记录执行的主类目和事件信息
if(this.logStartupInfo){
(newStartupInfoLogger(this.mainApplicationClass)).logStarted(this.getApplicationLog(),stopWatch);
}
启动所有的监听器对象
listeners.started(context);
执行所有的runner运行器
this.callRunners(context,applicationArguments);
}catch(Throwablevar9){
处理失败的操作
this.handleRunFailure(context,listeners,exceptionReporters,var9);
thrownewIllegalStateException(var9);
}
启动完成调用,发布应用上下文就绪事件
listeners.running(context);
返回应用上下文
return context;
}
springboot执行流程的更多相关文章
- SpringBoot项目构建、测试、热部署、配置原理、执行流程
SpringBoot项目构建.测试.热部署.配置原理.执行流程 一.项目构建 二.测试和热部署 三.配置原理 四.执行流程
- SpringBoot启动流程解析
写在前面: 由于该系统是底层系统,以微服务形式对外暴露dubbo服务,所以本流程中SpringBoot不基于jetty或者tomcat等容器启动方式发布服务,而是以执行程序方式启动来发布(参考下图ke ...
- Spring Boot程序的执行流程
Spring Boot的执行流程如下图所示:(图片来源于网络) 上图为SpringBoot启动结构图,我们发现启动流程主要分为三个部分,第一部分进行SpringApplication的初始化模块,配置 ...
- Spring Security Oauth2 单点登录案例实现和执行流程剖析
Spring Security Oauth2 OAuth是一个关于授权的开放网络标准,在全世界得到的广泛的应用,目前是2.0的版本.OAuth2在“客户端”与“服务提供商”之间,设置了一个授权层(au ...
- Spring Security 案例实现和执行流程剖析
Spring Security Spring Security 是 Spring 社区的一个顶级项目,也是 Spring Boot 官方推荐使用的安全框架.除了常规的认证(Authentication ...
- SpringBoot启动流程分析(六):IoC容器依赖注入
SpringBoot系列文章简介 SpringBoot源码阅读辅助篇: Spring IoC容器与应用上下文的设计与实现 SpringBoot启动流程源码分析: SpringBoot启动流程分析(一) ...
- SpringBoot启动流程分析(二):SpringApplication的run方法
SpringBoot系列文章简介 SpringBoot源码阅读辅助篇: Spring IoC容器与应用上下文的设计与实现 SpringBoot启动流程源码分析: SpringBoot启动流程分析(一) ...
- SpringBoot启动流程分析(三):SpringApplication的run方法之prepareContext()方法
SpringBoot系列文章简介 SpringBoot源码阅读辅助篇: Spring IoC容器与应用上下文的设计与实现 SpringBoot启动流程源码分析: SpringBoot启动流程分析(一) ...
- SpringBoot启动流程分析(四):IoC容器的初始化过程
SpringBoot系列文章简介 SpringBoot源码阅读辅助篇: Spring IoC容器与应用上下文的设计与实现 SpringBoot启动流程源码分析: SpringBoot启动流程分析(一) ...
随机推荐
- kafka生产者调优手册
目录 第一章 kafka硬件配置选择 1.1 场景说明 1.2 服务器台数选择 1.3 磁盘选择 1.4 内存选择(堆内存,页缓存) 1.4.1 堆内存配置 1.4.2 页缓存选择 1.5 cpu选择 ...
- Spring Boot-@EnableWebMvc注解
作用:当配置类中添加了该注解了之后,就表示某个模块的自动配置就都失效了,全部都要自己配置 例如下面这个MVC模块的配置类 /** * @author:抱着鱼睡觉的喵喵 * @date:2020/12/ ...
- PicCompress —— 一款精简的图片压缩工具
PicCompress 说明 之前上传博客图片过大不方便加载,还有一些微信平台的图片无法上传有大小限制,于是就打算开发个压缩图片的工具 支持图片格式 PNG(.png) JPEG(.jpg, .jpe ...
- Go xmas2020 学习笔记 08、Functions, Parameters & Defer
08-Functions, Parameters. functions. first class. function signatures. parameter. pass by value. pas ...
- 一行代码,让 VS Code 内置 PDF 阅读器变成深色模式
使用 CSS/JS 简单实现 PDF 深色模式.
- line-height: 1; line-height: 100%;是什么意思
先简单看个例子: css 页面: 应该猜测出来了: line-height: 1; = line-height: 100%; = font-size: 50px; 把哪一个放到最后都是一样的.我理解的 ...
- AngularJS性能优化心得,自己踩过的抗,及一些别人的经验(转哦)
脏数据检查 != 轮询检查更新 谈起angular的脏检查机制(dirty-checking), 常见的误解就是认为: ng是定时轮询去检查model是否变更.其实,ng只有在指定事件触发后,才进入$ ...
- php个人博客搭建第二阶段②
网站正文部分:热门博客的推荐: html代码: <!-- 网站正文部分 --> <div class="content"> < ...
- python代码统计核酸检测结果截图
#QQ:502440275@qq.com#本截图适合安康码截图,如需其他地区截图统计,可与我QQ或QQ邮箱联系#1.在当前文件夹下创建imgs文件夹用于存放图片,图片格式.jpg#2.在当前文件夹下创 ...
- C#接入SMTP邮件服务
我的个人博客 引入SMTP服务包 //引入邮件服务包using System.Net.Mail;using System.Net; 这两个引用用于C#接入邮件的SMTP服务 控件页面 定时器 为了给用 ...