Springboot 自动装配原理探索

简介: 官网介绍先来看看官网是怎么定义这个自动装配的~Spring Boot auto-configuration attempts to automatically configure your Spring application based on the jar dependencies that you have added可以看到这里说,当你引入了某个 jar 依赖包时,Springboot 会尝试根据这个依赖去自动配置 Spring 应用程序。

官网介绍



先来看看官网是怎么定义这个自动装配的~


Spring Boot auto-configuration attempts to automatically configure your Spring application based on the jar dependencies that you have added


可以看到这里说,当你引入了某个 jar 依赖包时,Springboot 会尝试根据这个依赖去自动配置 Spring 应用程序。


You need to opt-in to auto-configuration by adding the @EnableAutoConfiguration or @SpringBootApplication annotations to one of your @Configuration classes.


而且这里还说明了,你应该在 一个配置类 @Configuration 上选择 @EnableAutoConfiguration@SpringBootApplication 这其中的一个注解,来让自动配置生效.


网络异常,图片无法展示
|


那么,知道这些信息后,我们就开始愉快的看源码环节了~ 冲冲冲!😄


对了,探索的 Springboot 版本为 2.4.5


@SpringBootApplication


来到 @SpringBootApplication 注解中,可以发现它是一个组合注解,除了前面四个基本的元注解外,还有下面这三个 @SpringBootConfiguration@EnableAutoConfiguration@ComponentScan


源码如图


网络异常,图片无法展示
|


@SpringBootConfiguration


我们先来看这第一个注解,如图,可以发现它其实是一个 @Configuration 注解,

@Configuration 注解的作用是将其作为一个配置类,来配置 Spring 的上下文,相当于 SpringXML 配置文件中的 <beans>


源码如图


网络异常,图片无法展示
|


@ComponentScan


这个的作用就是 扫描指定路径下的组件,并加入到 IOC 容器 中,相当于

SpringXML 配置文件中的 <context:component-scan/>


源码如图


网络异常,图片无法展示
|


可以发现它里面有一个 @Repeatable(ComponentScans.class) 注解,表示可重复使用@ComponentScan 注解


网络异常,图片无法展示
|


注意,这里会按照我们自定义的方式去排除一些类,具体是通过实现 TypeFilter 接口并重写 match 方法来实现 。


小细节


这里还有个点要注意下~😄


AutoConfigurationExcludeFilter 会检查配置类,如果该配置类和 META-INF/spring.factories 文件中的 EnableAutoConfiguration 对应的配置类一样的话,会被排除掉~


@EnableAutoConfiguration


终于,来到本文的重点了  🐷


看到它的名字就知道它就是这个 自动配置 的主角了


源码如图


网络异常,图片无法展示
|


可以发现它是一个组合注解


先来看看这个注解1@AutoConfigurationPackage


@AutoConfigurationPackage


从名字就可以看出它是一个 自动配置包路径 的注解


源码如图


网络异常,图片无法展示
|


从这段注释我们可以发现,当没有配置这个 basePackages 或者

basePackageClasses 时,这个类就会自动将该注解所在的包作为基本路径进行注册

接着,我们再来看看这个框框里的内容~


@Import(AutoConfigurationPackages.Registrar.class) 🐷


@Import


先来看看这个注解的作用吧😋


源码如图


网络异常,图片无法展示
|


可以发现它的作用也很简单,就是导入组件,比如常见的 @Configuration 类或者ImportSelectorImportBeanDefinitionRegistrar实现类,或者其他一些常规的组件如 @Component@Service 等等


Registrar


继续看看这个 @Import(AutoConfigurationPackages.Registrar.class) ,可以发现该注解导入的是 Registrar 类 🐷 , 那么我们继续探索下,看看它干了什么~😄


源码如图


从该类的注解可以看出,它的作用是通过 ImportBeanDefinitionRegistrar **来保存这个基本包的路径的 **


网络异常,图片无法展示
|



那么,讲完第一点 ,我们简单了解到这个 @AutoConfigurationPackage  就是用来配置基本包 ,我们接着再来看看第二点,这个 @Import(AutoConfigurationImportSelector.class) 注解。


我们可以发现它导入了 AutoConfigurationImportSelector 类。


AutoConfigurationImportSelector


看这个名称,可以大概知道它是一个 组件选择器


关键步骤介绍


process


这个方法在获取这些 Import 类时会被调用,具体可以看结尾的流程图~


网络异常,图片无法展示
|


getAutoConfigurationEntry


获取自动配置实体类 ,里面还有本文的重点~


网络异常,图片无法展示
|


getCandidateConfigurations


来到这里,可以发现它调用到这个 SpringFactoriesLoader ,这里就不得不提下这个 SpringbootSPI 机制了,另外它和我们上文(服务发现机制SPI居然是破坏者?! )中提到的 Java Spi 有什么不同呢 ?


再继续往下看一下~😝


网络异常,图片无法展示
|


Springboot SPI机制


老规矩,看一眼注释先 哈哈😄


网络异常,图片无法展示
|


spring.factories 文件


举个栗子😄


# Run Listeners
org.springframework.boot.SpringApplicationRunListener=\
org.springframework.boot.context.event.EventPublishingRunListener
复制代码


可以发现它加载的是  META-INF/spring.factories 这个文件 ,相比 java 的  META-INF/services ,有以下的不同点:


  1. 从名字上就可以发现很大的不同( 一个是 factories 文件,一个是以接口全名命名的文件 )。


  1. spring.factories  以一个聚合的作用,把相应的接口和实现类以  key = value 形式展现在 spring.factories 文件中。


  1. spring.factories  中的所有配置项会加载到我们的缓存中,以  Map<String,List<String>> 形式存储,但不是所有的都会被实例化,被加载到 IOC 容器中,除了必要的类外( EventPublishingRunListener 等 ),还有满足特定条件下的自动配置类会被加载到 IOC 容器中


满足特定条件 ☞ 比如有没有使用到这个依赖( pom 中的 starter


自动配置类 ☞ 指以 AutoConfiguration 结尾的那些类


可以发现这种按需实现的机制比java的一股脑实现灵活多了~  😄


实例解析


比如 这里从 spring.factories  文件中加载了130个自动配置类


网络异常,图片无法展示
|


但是实际使用中,经过过滤后只有这 30 个了


网络异常,图片无法展示
|


这里还根据 优先级 做了一些排序~ 🐷


网络异常,图片无法展示
|


自动装配流程图



这里只摘了一些关键步骤~ ,具体流程太长了 ,得从 SpringApplication 源码中的 refreshContext(context);   这里就先不介绍啦,后面有时间再写一下分享下这个 [[Springboot源码的启动过程]]


网络异常,图片无法展示
|


同颜色的类名和方法块对应~


图中左下角的 processImports 方法,就是将这些自动配置类进行实例化,包括配置类里面的 @Import@Bean 等  ,一步步加载到 SpringIOC 容器中。


总结


一. Springboot 的自动装配很重要的一点就是,就是要在配置类上开启 @EnableAutoConfiguration 或者 @SpringBootApplication  注解,来让自动配置生效


二. 自动配置的核心是 SpringbootSPI 机制 ,以及组件选择器AutoConfigurationImportSelector,具体是通过其中的 getAutoConfigurationEntry 方法来获取 SPI 中的自动配置类并进行过滤,最后通过 processImports 将配置类加载到 IOC 容器中,完成自动配置



目录
相关文章
|
3月前
|
XML Java 开发者
Spring Boot开箱即用可插拔实现过程演练与原理剖析
【11月更文挑战第20天】Spring Boot是一个基于Spring框架的项目,其设计目的是简化Spring应用的初始搭建以及开发过程。Spring Boot通过提供约定优于配置的理念,减少了大量的XML配置和手动设置,使得开发者能够更专注于业务逻辑的实现。本文将深入探讨Spring Boot的背景历史、业务场景、功能点以及底层原理,并通过Java代码手写模拟Spring Boot的启动过程,为开发者提供一个全面的理解。
57 0
|
27天前
|
Dart 前端开发 JavaScript
springboot自动配置原理
Spring Boot 自动配置原理:通过 `@EnableAutoConfiguration` 开启自动配置,扫描 `META-INF/spring.factories` 下的配置类,省去手动编写配置文件。使用 `@ConditionalXXX` 注解判断配置类是否生效,导入对应的 starter 后自动配置生效。通过 `@EnableConfigurationProperties` 加载配置属性,默认值与配置文件中的值结合使用。总结来说,Spring Boot 通过这些机制简化了开发配置流程,提升了开发效率。
59 17
springboot自动配置原理
|
2月前
|
Java 数据库连接 Maven
最新版 | 深入剖析SpringBoot3源码——分析自动装配原理(面试常考)
自动装配是现在面试中常考的一道面试题。本文基于最新的 SpringBoot 3.3.3 版本的源码来分析自动装配的原理,并在文未说明了SpringBoot2和SpringBoot3的自动装配源码中区别,以及面试回答的拿分核心话术。
最新版 | 深入剖析SpringBoot3源码——分析自动装配原理(面试常考)
|
2月前
|
NoSQL Java Redis
Spring Boot 自动配置机制:从原理到自定义
Spring Boot 的自动配置机制通过 `spring.factories` 文件和 `@EnableAutoConfiguration` 注解,根据类路径中的依赖和条件注解自动配置所需的 Bean,大大简化了开发过程。本文深入探讨了自动配置的原理、条件化配置、自定义自动配置以及实际应用案例,帮助开发者更好地理解和利用这一强大特性。
147 14
|
3月前
|
Java Spring
SpringBoot自动装配的原理
在Spring Boot项目中,启动引导类通常使用`@SpringBootApplication`注解。该注解集成了`@SpringBootConfiguration`、`@ComponentScan`和`@EnableAutoConfiguration`三个注解,分别用于标记配置类、开启组件扫描和启用自动配置。
79 17
|
3月前
|
消息中间件 Java 数据库
解密Spring Boot:深入理解条件装配与条件注解
Spring Boot中的条件装配与条件注解提供了强大的工具,使得应用程序可以根据不同的条件动态装配Bean,从而实现灵活的配置和管理。通过合理使用这些条件注解,开发者可以根据实际需求动态调整应用的行为,提升代码的可维护性和可扩展性。希望本文能够帮助你深入理解Spring Boot中的条件装配与条件注解,在实际开发中更好地应用这些功能。
61 2
|
3月前
|
Java 容器
springboot自动配置原理
启动类@SpringbootApplication注解下,有三个关键注解 (1)@springbootConfiguration:表示启动类是一个自动配置类 (2)@CompontScan:扫描启动类所在包外的组件到容器中 (3)@EnableConfigutarion:最关键的一个注解,他拥有两个子注解,其中@AutoConfigurationpackageu会将启动类所在包下的所有组件到容器中,@Import会导入一个自动配置文件选择器,他会去加载META_INF目录下的spring.factories文件,这个文件中存放很大自动配置类的全类名,这些类会根据元注解的装配条件生效,生效
|
7月前
|
Java 应用服务中间件 开发者
Java面试题:解释Spring Boot的优势及其自动配置原理
Java面试题:解释Spring Boot的优势及其自动配置原理
147 0
|
4月前
|
Java Spring 容器
springboot @RequiredArgsConstructor @Lazy解决循环依赖的原理
【10月更文挑战第15天】在Spring Boot应用中,循环依赖是一个常见问题,当两个或多个Bean相互依赖时,会导致Spring容器陷入死循环。本文通过比较@RequiredArgsConstructor和@Lazy注解,探讨它们解决循环依赖的原理和优缺点。@RequiredArgsConstructor通过构造函数注入依赖,使代码更简洁;@Lazy则通过延迟Bean的初始化,打破创建顺序依赖。两者各有优势,需根据具体场景选择合适的方法。
211 4
|
5月前
|
Java 应用服务中间件 API
Vertx高并发理论原理以及对比SpringBoot
Vertx 是一个基于 Netty 的响应式工具包,不同于传统框架如 Spring,它的侵入性较小,甚至可在 Spring Boot 中使用。响应式编程(Reactive Programming)基于事件模式,通过事件流触发任务执行,其核心在于事件流 Stream。相比多线程异步,响应式编程能以更少线程完成更多任务,减少内存消耗与上下文切换开销,提高 CPU 利用率。Vertx 适用于高并发系统,如 IM 系统、高性能中间件及需要较少服务器支持大规模 WEB 应用的场景。随着 JDK 21 引入协程,未来 Tomcat 也将优化支持更高并发,降低响应式框架的必要性。
127 6
Vertx高并发理论原理以及对比SpringBoot