springbootalready右耳菌-邓小白的Java架构师的修炼之路

SpringBoot 系统配置自动装载机制

2022-07-19  本文已影响0人  右耳菌

一、@SpringBootApplication注解

这个注解相当于三个注解的功能集成

@Target({ElementType.TYPE})
@Retention(RetentionPolicy.RUNTIME)
@Documented
@Inherited
// 以下三个注解是SpringBoot中非常重要的内容
@SpringBootConfiguration
@EnableAutoConfiguration
@ComponentScan(excludeFilters = {
    @Filter(    type = FilterType.CUSTOM,  classes = {TypeExcludeFilter.class}), 
    @Filter(    type = FilterType.CUSTOM,  classes = {AutoConfigurationExcludeFilter.class}) })
public @interface SpringBootApplication {
1. @SpringBootConfiguration
@Target({ElementType.TYPE})
@Retention(RetentionPolicy.RUNTIME)
@Documented
@Configuration
public @interface SpringBootConfiguration {
}

可以看到上边的代码中,@SpringBootConfiguration 注解的上方还有一个@Configuration的注解内容,表示这个注解本质来说也就是一个Configuration,即这就是SpringBoot为什么不需要xml配置文件的原因,总的来说,这个注解允许了配置bean和导入其他的配置类的行为。

2. @EnableAutoConfiguration
@Target({ElementType.TYPE})
@Retention(RetentionPolicy.RUNTIME)
@Documented
@Inherited
@AutoConfigurationPackage
@Import({AutoConfigurationImportSelector.class})
public @interface EnableAutoConfiguration {
    String ENABLED_OVERRIDE_PROPERTY = "spring.boot.enableautoconfiguration";

    Class<?>[] exclude() default {};

    String[] excludeName() default {};
}

这个注解总的来说就是为了解决自动装配的问题,即 启用Spring Boot的自动bean加载机制,具体的内容,后续再进行描述。

3. @ComponentScan
@Retention(RetentionPolicy.RUNTIME)
@Target(ElementType.TYPE)
@Documented
@Repeatable(ComponentScans.class)
public @interface ComponentScan {
    ...
}

这个就是自动扫描包的注解配置,具体需要注意的点就是这段注释

 * <p>Either {@link #basePackageClasses} or {@link #basePackages} (or its alias
 * {@link #value}) may be specified to define specific packages to scan. If specific
 * packages are not defined, scanning will occur from the package of the
 * class that declares this annotation.

转译成中文的意思大概就是,如果注解上没有配置 basePackageClassesbasePackages, 则会默认扫描当前注解声明的类的包路径。


二、代码包扫描

如下图所示,如果SpringBootApplication注解没有定义包路径scanBasePackages,则会自动默认扫描与Application.java这个类所属包下的内容。

默认的包结构及其作用

  1. 主程序Application.java放在根包,在其他类之上。
  2. @SpringBootApplication注解写在主程序上。
  3. Spring对类的扫描默认仅涵盖主程序所在的包及子包

注意: 如果定义了 scanBasePackageClassesscanBasePackages,可能会导致启动类包路径下的bean无法被扫描到,所以启动类的包路径也要加入进去,避免出现无法正常扫描包的问题。


三、零Spring配置文件

SpringBoot中建议放弃通过XML定义Spring应用程序,推荐在代码类上面通过@Configuration实现配置。如有需要,还可以通过@lmportResource来导入xml配置文件。

即通俗点来说,在SpringBoot项目中,最好不要使用xml的配置文件,而使用@Configuration定义相关的类,如果真的有需要,请使用@ImportResource来导入xml配置文件。

注:要使@Configuration生效,你需要将它写在SpringBoot入口程序类上面,或者使用@EnableAutoConfiguration或 @SpringBootApplication这两个注解来开启自动加载功能。


四、个性化加载配置


五、外部参数配置信息加载

Spring应用程序可以通过属性文件,YAML文件,环境变量和命令行参数等方式的外部化参数配置


没有创建application.yml文件的时候使用这种方式

java -jar springboot-demo-1.0.0.jar --spring.profile.active="test"
java -jar springboot-demo1-1.0.0.jar --SPRING_APPLICATION_JSON="{\"spring.profiles.active\":\"dev\"}"

一般来说,我们创建一个SpringBoot项目,一般都有好几个yml文件,如:

  • application.yml 主文件
  • application-dev.yml 开发环境配置
  • application-test.yml 测试环境配置
  • application-prod.yml 生产环境配置

以上的几个配置文件分别是使用在不同的环境下的,但是我们可以通过修改application.yml的内容,来决定使用哪个文件,如下方所示:



这里表示使用的开发环境的配置文件。

        SpringApplication springApplication = new SpringApplication(Example.class);
        springApplication.setAdditionalProfiles();
        Properties properties = new Properties();
        properties.setProperty("name", "setDefaultProperties-tony");
        springApplication.setDefaultProperties(properties);
        springApplication.run(args);

六、环境化配置 - profile


七、配置文件

上述配置文件按优先级排列,排在上面的位置会覆盖优先级降低的配置。


八、配置文件格式

SpringBoot支持两种配置文件的格式: .properites、.yml

yaml语法精简版说明:

properites示例:
spring.datasource.username=test


九、参数使用

方式一:
通过@Value("${my.name}")注解y将指定的参数配置注入到属性。

方式二:
注入Environment对象。

方式三:
通过注解@ConfigurationProperties(prefix = "my")
将注解加在指定的类上,spring会为实例对象的属性进行赋值,属性需有getters和setters方法。


如果觉得有收获就点个赞吧,更多知识,请点击关注查看我的主页信息哦~

上一篇 下一篇

猜你喜欢

热点阅读