前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Spring Boot -- 自动配置原理

Spring Boot -- 自动配置原理

作者头像
屈定
发布2020-02-10 17:13:02
5840
发布2020-02-10 17:13:02
举报
文章被收录于专栏:屈定‘s Blog屈定‘s Blog

启用自动配置

在Spring Boot中自动配置一般使用@EnableXXX方式,Spring默认提供了@EnableAutoConfiguration来配置starter,另外还提供了类似@EnableScheduling来配置非starter的相关bean,从源码角度来看,两种方式本质上来说并没什么区别,其都使用了@Import来导入一个对应的配置入口类,然后正在启动中的Spring IoC容器会尝试初始化该类,那么该配置入口类相当于拿到了ApplicationContext,自然可以做很多的自由发挥。

清单1:EnableAutoConfiguration源码

代码语言:javascript
复制
@Target(ElementType.TYPE)
@Retention(RetentionPolicy.RUNTIME)
@Documented
@Inherited
@AutoConfigurationPackage
@Import(EnableAutoConfigurationImportSelector.class)
public @interface EnableAutoConfiguration {

	String ENABLED_OVERRIDE_PROPERTY = "spring.boot.enableautoconfiguration";
    // .......
}

清单2:EnableScheduling源码

代码语言:javascript
复制
@Target(ElementType.TYPE)
@Retention(RetentionPolicy.RUNTIME)
@Import(SchedulingConfiguration.class)
@Documented
public @interface EnableScheduling {

}

如何自动配置

所谓的自动配置就是执行具体的Configuration类,首先先看比较简单的@EnableScheduling注解,该注解对应的配置类为SchedulingConfiguration,在SchedulingConfiguration中往IOC中注入了一个DestructionAwareBeanPostProcessor处理器,用于扫描定时器方法,然后初始化整个定时器调度。

这个简单的自动配置也说明了@EnableXXX本质上是一个开关,告诉Spring该去配置哪些东西,该怎么配置这些东西。

清单3:EnableScheduling对应的SchedulingConfiguration配置

代码语言:javascript
复制
@Configuration
@Role(BeanDefinition.ROLE_INFRASTRUCTURE)
public class SchedulingConfiguration {

	@Bean(name = TaskManagementConfigUtils.SCHEDULED_ANNOTATION_PROCESSOR_BEAN_NAME)
	@Role(BeanDefinition.ROLE_INFRASTRUCTURE)
	public ScheduledAnnotationBeanPostProcessor scheduledAnnotationProcessor() {
		return new ScheduledAnnotationBeanPostProcessor();
	}
}

那么对于starter模块是如何做到自动配置的呢?答案是@EnableAutoConfiguration,该注解对应的配置类为EnableAutoConfigurationImportSelector,该类实现了ImportSelector接口,在Spring Boot的Application Context启动时会主动调用其org.springframework.context.annotation.ImportSelector#selectImports方法,那么自动注入的核心就在该方法中。

EnableAutoConfigurationImportSelector在启动后回去扫描META-INF/spring.factories文件,该文件是Spring Boot提供的Starter自我配置的入口,以mybatis starter为例,其形式如下:

清单4: mybatis starter配置

代码语言:javascript
复制
# Auto Configure
org.springframework.boot.autoconfigure.EnableAutoConfiguration=\
org.mybatis.spring.boot.autoconfigure.MybatisAutoConfiguration

其目地告诉Spring Boot使用org.mybatis.spring.boot.autoconfigure.MybatisAutoConfiguration来配置我这个模块,Spring Boot获取到该配置后会经过一系列的判断(比如是否被用户手动exclude),然后决定加载后将该类纳入Spring Boot的配置中去,让IoC容器去完成配置。到此整个自动配置发现流程就算完成,这种方式类似Java提供的SPI,利用classpath下的配置信息达到批量自动配置的目地。

如何利用自动配置

自动配置的原理是很简单的,总结起来就两种,如果你想要让用户主动配置,那么可以提供一个自定义的EnableXXX注解,在该注解中import对应的配置类,如果你想让Spring Boot再启动的时候自动配置,那么在META-INF下提供对应的spring.factories文件,让Spring自动加载对应的配置类。

Spring Boot利用这种做法能让模块与模块之间解耦,所有的模块之间通过IoC容器进行联系,那么对写代码就很有启发了,比如在项目中要对接多个短信服务商,那么每一个短信服务商实际上就是一个Plugin,那么给每一个服务商写一个EnableXXX注解,让Spring自动配置到IoC容器中,使用方也只需要从IoC中获取,也是一种不错的解耦的设计。

参考

Creating Your Own Auto-configuration

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2019-01-19,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 启用自动配置
  • 如何自动配置
  • 如何利用自动配置
  • 参考
相关产品与服务
容器服务
腾讯云容器服务(Tencent Kubernetes Engine, TKE)基于原生 kubernetes 提供以容器为核心的、高度可扩展的高性能容器管理服务,覆盖 Serverless、边缘计算、分布式云等多种业务部署场景,业内首创单个集群兼容多种计算节点的容器资源管理模式。同时产品作为云原生 Finops 领先布道者,主导开源项目Crane,全面助力客户实现资源优化、成本控制。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档