Spring Boot 的配置和自动配置原理
配置文件
properties yml yaml
位置优先级 由低到高
classpath根目录下
classpatch根config
项目根目录
项目根目录/config
直接子目录/config 命令行 启动 加 --server.port=8081 或者指定文件或文件夹
spring profiles 指定配置文件,可以互补
spring config 指定配置文件,不会互补
所有配置文件按照从低到高 yml->yaml->properties
1.打包在jar中的配置文件
2.打包在jar中的profile
3.打包的jar之外的配外文件
4.打包的jar之外的profile
例子
在application.properties配置端口8081
在resources下新建app.properties,设置端口8080,设置虚拟路径未为/yutong在Springboot的启动类中读取app.properties配置信息加入到Springboot启动,可以看到application.properties端口覆盖掉了app.properties,且形成了互补.
static 静态资源
templates
松散绑定
蛇形
串形
全大写
@ConfigurationProperties与@Value获取值比较
@ConfigurationProperties | @Value | |
---|---|---|
绑定 | 批量注入配置文件中的属性 | 一个个指定 |
松散绑定(松散语法) | 支持 | 支持有限 |
SpEL | 不支持 | 支持 |
自动提示 | 支持 | 不支持 |
JSR303数据校验
@SpringBootApplication 注解解析
@Target({ElementType.TYPE}) 当前注解可以标记在哪
@Retention(RetentionPolicy.RUNTIME) 当注解标记的类以什么方式保留 runtime 会被JVM加载
@Documented Java doc 会生成注解信息
@Inherited 是否会被集成
@SpringBootConfiguration SpringBoot的配置类 标注在某个类上,表示这个一个SpringBoot的配置类
@EnableAutoConfiguration 开启自动配置功能
@ComponentScan(
excludeFilters = {@Filter(
type = FilterType.CUSTOM,
classes = {TypeExcludeFilter.class}
), @Filter(
type = FilterType.CUSTOM,
classes = {AutoConfigurationExcludeFilter.class}
)}
) 扫描包 相当于spring.xml 中的<context:comonent-scan> 但是没有指定basepackage ,如果没有指定spring底层就会自动扫描当前配置类所有的包
TypeExceludeFiler SpringBoot对外提供的扩展类,可以供我们去按照我们的方式进行排除
AutoConfigurationExcludeFiler 排除所有配置;类并且是自动配置类中里边的一个
自动配置原理
流程图
简单叙述一下,就是通过配置扫描读取固定路径的配置文件(jar包内的properties),读取文件内所有的全类名,有的类压根加载不到,就像下面这个RabbitAutoConfig我maven没有相关依赖。还有些就是这些类名上会有限制的注解不满足条件也不会启动。