SpringBoot基础之配置详解

大家好,我是二师兄,本篇文章为大家讲解SpringBoot相关配置功能,包括application.properties配置文件、外部配置、属性注入等。


配置文件

基本配置支持

创建SpringBoot项目,会在src/main/resources目录下生成application.properties文件,这就是SpringBoot默认指定的配置文件。基本使用方式如下:


server.port=8080

server.servlet.context-path=/hello


同时,SpringBoot也支持YAML格式的配置,同样将application.yml文件放置在resources目录下即可。YAML是以数据为中心的语言,配置的时候具有面向对象的特性。这两种配置形式都是SpringBoot推荐的,但对于比较复杂的数据来说,yaml的配置要优于properties。yaml配置具体示例:


server:

  port: 8080

  servlet:

     context-path: /hello


YAML基本要求:


YAML大小写敏感;

使用缩进代表层级关系;

缩进只能使用空格,不能使用TAB,不要求空格个数,只需要相同层级左对齐(一般2个或4个空格)

如果一个项目中同时出现application.properties和application.yml文件配置的话,SpringBoot会如何处理呢?会优先使用properties中属性,然后再考虑使用yml文件中的属性。比如,上面的例子中,如果properties中不配置port,而yml配置port为8081,则启动后端口为8081,但是如果properties中配置为8080,则启动时以properties为准。


配置文件源代码解析

为什么我们将配置文件放置在resources目录下,SpringBoot就可以帮忙我们进行解析加载?下面通过源代码看一下SpringBoot默认会扫描哪些路径下的哪些配置文件。来看一下ConfigFileApplicationListener类,该类在spring-boot包下,通过该类的注释可以了解到基本的加载信息。


package org.springframework.boot.context.config;

public class ConfigFileApplicationListener
        implements EnvironmentPostProcessor, SmartApplicationListener, Ordered {

    private static final String DEFAULT_PROPERTIES = "defaultProperties";

    // Note the order is from least to most specific (last one wins)
    private static final String DEFAULT_SEARCH_LOCATIONS = "classpath:/,classpath:/config/,file:./,file:./config/";

    private static final String DEFAULT_NAMES = “application”;

      // 省略其他代码
}

通过该类的常量定义,我们可以看到,默认加载的配置文件名为application,会加载以下目录下的配置文件:classpath目录、classpath目录下的config目录、工程根目录下、工程根目录的config目录下。


它们的优先级依次为:


工程根目录:./config/

工程根目录:./

classpath:/config/

classpath:/

SpringBoot也支持通过命令来指定配置文件的位置:


--spring.config.location=/usr/local/config/


使用xml配置

当无法避免使用xml配置时,可以采用@ImportResources来进行xml配置的加载。


@ImportResource("classpath:mq.xml")


命令行参数配置

除了上面的参数配置之外,SpringBoot还提供了命令参数配置,比如在运行jar -jar时可以添加一些额外的参数来进行指定。


java -jar xx.jar —server.port=8080


此种方式的优先级最高。


自定义配置属性

除了可以按照SpringBoot的约定配置参数之外,我们还可以自定义一些参数,然后通过@Value或@ConfigurationProperties进行配置。也可以不使用默认的配置文件名,而通过@PropertiesSource进行配置文件路径的指定。


@Value注入属性值

在application配置文件中自定义好具体的属性,然后通过@Value注解在需要使用的地方进行注入。属性的自定义:


# 自定义属性

admin.name=Tom

admin.age=25

admin.phone=156********


在需要对应属性的地方注解使用,其中在表达冒号后面的Guest为指定的默认值,即如果找不到admin.name,则使用此默认值。


@Value("${admin.name:Guest}")

private String adminName;


@RequestMapping("/hello")

public String hello(){

return "Hello admin:" + adminName + "!";

}


@ConfigurationProperties配置

SpringBoot还提供了基于类型安全的配置方式,通过@ConfigurationProperties将一组配置和一个Bean关联起来,批量进行类型安全的自动注入。


@Component
@PropertySource("classpath:my.properties")
@ConfigurationProperties(prefix = "admin")
public class SystemAdmin {

    private String name;

    private int age;
       // 省略getter/setter方法
}

其中,@Component表示将此类实例化,@PropertySource指定自定义的properties文件,@ConfigurationProperties(prefix = “admin”)指定实现配置属性和bean直接的关联,prefix指定匹配属性的前缀都以admin开始。


其中,@Component表示将此类实例化,@PropertySource指定自定义的properties文件,@ConfigurationProperties(prefix = “admin”)指定实现配置属性和bean直接的关联,prefix指定匹配属性的前缀都以admin开始。


@ConfigurationProperties的使用支持松散绑定,如:驼峰命名(userName)、横干拼接(user-name)、下划线(user_name)之间可以互相识别绑定。


绑定对象的使用:


@Resource
private SystemAdmin systemAdmin;

@RequestMapping("/hello")
public String hello(){
    return "Hello admin:" + systemAdmin.getName() + "!";
}

profile配置

在真是实践中,我们的配置文件会根据不同的环境有不同的配置文件,SpringBoot也为我们准备好了相应的配置。首先不同环境的配置按照指定的格式进行命名。比如:


开发环境:application-dev.properties

测试环境:application-test.properties

生产环境:application-prod.properties

Spring Boot 则通过 application.properties 文件中设置 spring.profiles.active 属性来指定加载文件。比如 ,参数值配置为 dev ,则加载的是 application-dev.properties 。



上一篇:Spring Cloud构建微服务架构:服务注册与发现(Eureka、Consul)【Dalston版】


下一篇:项目管理系列之质量管理(一)