微服务

SpringBoot使用yml配置文件

2020-03-05  本文已影响0人  茶还是咖啡

1. @Value("${变量名称}")

使用@Value("${变量名称}")是最简单的一种形式
代码中直接通过该方式引用即可

public class MicroGatewayConfig {
    @Value("${config}")
    private String config;
}

这种方式简单粗暴,但是不推荐使用,

缺点很多
  1. idea也给我们报黄色的警告。而且我们不能再配置文件中按住“ctrl”鼠标点击配置变量直接跳到程序中。如果我们的项目中使用大量这样的变量,将会是灾难。
  2. 最致命的问题是程序中变量获取到的值只能是字符串,不能支持数字,布尔类型。
  3. 使用这种形式,变量的值只会在SpringBoot启动的时候赋值一次,以后不会改变,如果我们使用了配置中心,随后,我们即使更新了配置中心中配置信息的值,程序也不会同步,除非我们重启项目,配置中心就显得比较尴尬。


2.1 配置类

@Setter
@Getter
@Component
@ConfigurationProperties("spring.cloud.gateway.custom")
public class MicroGatewayConfig {
    /**
     * config demo
     */
    private String config;
}

@ConfigurationProperties注解内容填写的是这个配置变量的前缀
这样配置信息就以类的形成呈现出来,如果我们需要使用配置信息,直接通过@Resource注入即可。在配置文件中,也不会报警告,在编写配置信息的时候,强大的idea也会帮我们联想。

2.2 配置类嵌套

当我们的配置信息越来越多时,需要针对不同的配置进行分类,如果全部编写在同一个配置类中,那么这个配置类会显得十分臃肿。
springBoot支持配置类嵌套的形式。

举个例子
我现在网关通过配置文件中的“开关”决定是否对请求信息进行缓存。
这样,我们可以将关于请求缓存相关的配置信息单独一个类进行保存。

  1. 缓存配置类
@Data
@Component
@ConfigurationProperties("spring.cloud.gateway.custom.cache-request")
public class CacheRequestConfig {
    /**
     * 是否缓存body信息
     */
    private Boolean body = false;
    /**
     * 是否缓存表单信息
     */
    private Boolean formData = false;
    /**
     * 是否缓存encodeBody信息
     */
    private Boolean encodeFormData = false;
}
  1. 主配置类
@Setter
@Getter
@Component
@ConfigurationProperties("spring.cloud.gateway.custom")
public class MicroGatewayConfig {
    private CacheRequestConfig cacheRequest;
}
  1. 配置文件


    image.png

    我们在编写配置类的时候,可以发现一个有趣的事情,就是针对于布尔类型,我们除了使用true/false外,还可以使用on/off进行代替,在程序中springBoot会自动替我们转换成true/false。这样增强了配置的可读性。

2.3 List配置信息

我们在配置信息中有时候可能需要配置一个list,比如配置redis的集群ip信息。之前我们可以使用一个字符串代替,每个ip中间使用特定的符号隔开,然后在程序中自己手动的去分隔。

强大的yml支持List,表达形式是每个元素前面使用“-”+空格
eg:
配置一个redis集群列表

  1. 配置类
@Data
@Component
@ConfigurationProperties("spring.cloud.gateway.custom")
public class MicroGatewayConfig {

    private CacheRequestConfig cacheRequest;

    private List<String> redisClusterPortList;
}
  1. 配置信息
spring:
  cloud:
    gateway:
      custom:
        cache-request:
          body: true
          form-data: true
          encode-form-data: on
        redisClusterPortList:
          - 192.168.1.1
          - 196.168.1.0

2.3 Map配置信息

yml使用map的格式为:

map变量名
  key: value
  key: value

这里举例配置一个日志打印相关的

  1. 配置类
@Data
@Component
@ConfigurationProperties("spring.cloud.gateway.custom")
public class MicroGatewayConfig {

    private CacheRequestConfig cacheRequest;

    private List<String> redisClusterPortList;

    private Map<String,Boolean> logPrint;
}
  1. 配置信息
spring:
  cloud:
    gateway:
      custom:
        cache-request:
          body: true
          form-data: true
          encode-form-data: on
        redisClusterPortList:
          - 192.168.1.1
          - 196.168.1.0
        logPrint:
          printRequestHeader: false
          printResponseHeader: false
          printRequestBody: false
          printResponseBody: false

map的形式个人不推荐使用,因为我们编写的key-value没有在配置文件中体现出来,可读性可能会差一点,如果我们使用map中的key,还需要使用一个常量类去记录map中存了啥,感觉实在是多此一举,map也完全可以通过自己编写配置类实现。

上一篇 下一篇

猜你喜欢

热点阅读