SpringBoot2.0学习第五篇之autoconfigure自动化配置

举报
西魏陶渊明 发表于 2022/09/25 03:14:10 2022/09/25
【摘要】 何为自动化配置? 通读全文大概需要1分钟 image 不知道用过SpringBoot的同学,有没有发现在SpringBoot的maven依赖中经常会有很多的starter之类的依赖,往往这些依赖的框架,在加入到pom之后,当应用启动时候就会自动的被应用整合起来...

何为自动化配置?

通读全文大概需要1分钟

4279695-953eb618d2fb3572
image

不知道用过SpringBoot的同学,有没有发现在SpringBoot的maven依赖中经常会有很多的starter之类的依赖,往往这些依赖的框架,在加入到pom之后,当应用启动时候就会自动的被应用整合起来

比如昨天我们的thymeleaf教程中,SpringBoot在整合thymeleaf的时候,只是引入了spring-boot-starter-thymeleaf依赖就可以直接使用了,类似的还有很多。

比如: 自动整合freemarker


  
  1. <dependency>
  2. <groupId>org.springframework.boot</groupId>
  3. <artifactId>spring-boot-starter-freemarker</artifactId>
  4. </dependency>

自动整合mybatis


  
  1. <dependency>
  2. <groupId>org.mybatis.spring.boot</groupId>
  3. <artifactId>mybatis-spring-boot-starter</artifactId>
  4. </dependency>

现在不懂这些都没关系,本节课小编就教大家如何使用自动化配置。

说道自动化配置这其实是SpringBoot的一个小特性。不知道有没有同学仔细研究过SpringBootApplication这个注解主要有什么作用。其实自动化配置的秘密就隐藏在这里。

4279695-6a3c6aaabb7c075d.jpg
image-20190307215219386

跟着小编来找一下秘密到底在哪里。

4279695-8d412f77ea584b00.jpg
image-20190307215359080

秘密就是: EnableAutoConfiguration

这个类的含义就是自动在依赖中找到自动化配置类。为了更简单的给各位小伙伴说清出。下面

小编举一个例子thymeleaf。我们看下thymeleaf是如何实现自动化配置的吧。thymeleaf的自动化类就是这个:

ThymeleafAutoConfiguration。 前面我们说了SpringBoot的自动化配置的秘密是EnableAutoConfiguration.。那么我们看ThymeleafAutoConfigurationEnableAutoConfiguration到底有什么关系呢?

谜底大解开

SpringBoot项目启动类必须要被EnableAutoConfiguration标记,而之所以我们没有看到是因为,SpringBootApplication已经被EnableAutoConfiguration标记了。

4279695-2bab570098784046.jpg
image-20190307220020658

那么SpringBoot会在他依赖的所有包中去查找一个叫spring.factories的文件,ThymeleafAutoConfigurationEnableAutoConfiguration的关系就在spring.factories里面声明。我们打开

spring.factories文件发现EnableAutoConfiguration其实于很多的自动化配置做了绑定。当EnableAutoConfiguration被加载其实与其绑定的这么多自动化配置都会选择的进行启动。

4279695-adc629199c24741c.jpg
image-20190307220530562
4279695-7929d36fc6c2989f.jpg
image-20190307220551258

到这里我们就知道了为啥当引入了thymeleaf就会自动被整合到SpringBoot中了吧。如果只知道以上这些其实还是不够的。下面小编提出一个问题。

请思考:

SpringBoot中自动化配置会自动整合ThymeleafAutoConfiguration但是假如我们不引入thymeleaf它的实现类,那么自动整合时候就会报中NoSuchClassException异常。SpringBoot是如何解决呢?

我们看ThymeleafAutoConfiguration是如何实现的。

4279695-2dc261c063fcabbd.jpg
image-20190307221503220

答案就在这些注解上面。

  • @ConditionalOnClass : classpath中存在该类时起效
  • @ConditionalOnMissingClass : classpath中不存在该类时起效
  • @ConditionalOnBean : DI容器中存在该类型Bean时起效
  • @ConditionalOnMissingBean : DI容器中不存在该类型Bean时起效
  • @ConditionalOnSingleCandidate : DI容器中该类型Bean只有一个或@Primary的只有一个时起效
  • @ConditionalOnExpression : SpEL表达式结果为true时
  • @ConditionalOnProperty : 参数设置或者值一致时起效
  • @ConditionalOnResource : 指定的文件存在时起效
  • @ConditionalOnJndi : 指定的JNDI存在时起效
  • @ConditionalOnJava : 指定的Java版本存在时起效
  • @ConditionalOnWebApplication : Web应用环境下起效
  • @ConditionalOnNotWebApplication : 非Web应用环境下起效

SpringBoot如何来判断是否启动自动化配置,防止报错呢? 就是通过上面的条件注解来实现。只要满足条件的配置类,才会被整合进去。

实现一个自动化配置项目实战?

我们以github上一个项目为例

4279695-654d5677a47072fa.jpg
image-20190307221949850

使用方法.(和SpringCloud中Hystrix的使用方法类似,当getUserName出现报错之后,就返回其指定的备用方法)


  
  1. @Service
  2. public class UserServiceImpl {
  3. @TurnoffCommand(fallbackMethod = "getBreakUserName")
  4. public String getUserName(String name) {
  5. throw new RuntimeException();
  6. }
  7. public String getBreakUserName(String name) {
  8. return "Mock用户id:" + name;
  9. }
  10. }

该项目可以自动化配置.


  
  1. <!--熔断-->
  2. <dependency>
  3. <groupId>com.github.lxchinesszz</groupId>
  4. <artifactId>turnoff-spring-boot-starter</artifactId>
  5. <version>1.0.1</version>
  6. </dependency>

我们看他是如何实现自动化配置的吧。

Turnoff的配合类就下面这么简单。

4279695-1fe9276dd950b8cc.jpg
image-20190307222656553

只用在META-INF目录中创建一个spring.factories就可以实现。是不是很简单。

4279695-817d90a902b6b30b.jpg
image-20190307222745611

到这里本篇内容就讲完了,相信各位看官已经明白了吧。

获取本课程代码请关注头条号: 软件编程指南 ,私信: 005

更多了解可以点击小编博客: https://blog.springlearn.cn/posts/4135/

文章来源: springlearn.blog.csdn.net,作者:西魏陶渊明,版权归原作者所有,如需转载,请联系作者。

原文链接:springlearn.blog.csdn.net/article/details/102425357

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。