ToB企服应用市场:ToB评测及商务社交产业平台

标题: Spring Cloud开发实践(七): 集成Consul配置中心 [打印本页]

作者: 河曲智叟    时间: 2023-6-1 20:09
标题: Spring Cloud开发实践(七): 集成Consul配置中心
目录

Spring Cloud Consul Config

Consul 通过 Key/Value 功能集中管理存储配置信息, 通过 Spring Cloud Consul Config 可以实现 Config Server 和 Client 的关联. 在 Spring 启动的 bootstrap 阶段, 配置会被载入环境上下文.
配置前缀, 路径和优先级

默认情况下, 配置的路径前缀是 /config , 不同的 application 和 profile 对应不同的配置路径, 例如对应应用 "testApp" 和 "dev" profile 的配置, 会涉及以下路径
  1. config/testApp,dev/
  2. config/testApp/
  3. config/application,dev/
  4. config/application/
复制代码
这个列表从上往下分别对应的配置优先级从高到低, 优先级高的同样配置项会覆盖优先级低的配置项.
注意: 配置对应的 profile 和节点应用名是平级的, config/service-name,dev/data 这样, data 是配置的子项, 不要把 profile 加到 data 去了
在项目中启用 Consul Config

如果要使用 Consul 的分布式配置(Distributed Configuration), 需要添加 spring-cloud-starter-consul-config 的依赖
spring-cloud-starter-consul-discovery 不带 spring-cloud-starter-consul-config, 如果需要用 Consul Config, 需要单独添加依赖
  1. <dependency>
  2.     <groupId>org.springframework.cloud</groupId>
  3.     <artifactId>spring-cloud-starter-consul-config</artifactId>
  4. </dependency>
复制代码
也可以直接用 spring-cloud-starter-consul-all, 包含了 spring-cloud-starter-consul-discovery 和 spring-cloud-starter-consul-config
  1. <dependency>
  2.     <groupId>org.springframework.cloud</groupId>
  3.     <artifactId>spring-cloud-starter-consul-all</artifactId>
  4. </dependency>
复制代码
配置文件 application.yml

添加了 consul-config 依赖之后, 在 application.yml 就要增加对应的设置 spring.config.import = consul: 否则启动会报错,
Spring Boot 在 2.4 版本之后新增了这个项(spring.config.import property)用于导入配置, 并且是默认的配置方式.
  1. # properties
  2. spring.config.import=optional:consul:
  3. # yaml
  4. spring:
  5.   config:
  6.     import: 'consul:'
复制代码
上面的配置, 如果启动时import失败会导致启动失败, 如果不强制 import, 可以加上 optional:
  1. # properties
  2. spring.config.import=optional:consul:
  3. # yaml
  4. spring:
  5.   config:
  6.   import: 'optional:consul:'
复制代码
上面的这两个配置, 都会用默认的地址 http://localhost:8500 去请求 Consul 服务, 如果需要自定义地址, 可以通过配置spring.cloud.consul.host和spring.cloud.consul.port,
  1. spring:
  2.   cloud:
  3.     consul:
  4.       host: 10.123.123.123
  5.       port: 8501
复制代码
或者使用
  1. spring.config.import=optional:consul:myhost:8500
复制代码
对应以上配置, 在 Spring 启动的 bootstrap 阶段会通过 Consul 去获取 key = config/dummy-service/data 对应的 value (假定这个模块的 application.name = dummy-service),
对应value格式为 yaml, 需要增加配置
  1. # yaml
  2. spring:
  3.   cloud:
  4.     consul:
  5.       config:
  6.         format: YAML
  7.         prefix: config
  8.         data-key: data
复制代码
其中
默认的请求路径生成基于
如果不想用默认的, 想自己指定, 可以用如下的方式
  1. # properties
  2. spring.config.import=optional:consul:myhost:8500/config/custom/context/one;/config/custom/context/two
复制代码
上面的设置将只从这两个Key/Value路径读取配置, 注意路径的对应关系, 在import中体现前缀 config, 但是不体现后缀 data
配置自动更新, Config Watch

Consul Config Watch 使用 consul 的路径前缀对配置更新进行检查, 当配置变化时会产生一个 Refresh Event, 等价于请求 /refresh actuator endpoint.
默认的检查频率为 1000 单位毫秒, 可以通过 spring.cloud.consul.config.watch.delay 配置
如果要禁用配置自动更新, 需要设置 spring.cloud.consul.config.watch.enabled=false
Consul 配置管理

通过 WEB 界面

默认为 http://127.0.0.1:8500 可以在 Key/Value 中直接添加, 记得格式要改为 YAML
通过命令行

读取
  1. $ ./consul kv get foo
  2. bar
  3. $ ./consul kv get config/application/data
  4. cassandra:
  5.   host: 127.0.0.1:9042,127.0.0.2:9042
  6.   user: my_user
  7.   password: my_pass
复制代码
使用文件data.yml中的内容, 直接写入
  1. $  ./consul kv put config/application/data @data.yml
  2. Success! Data written to: config/application/data
  3. The data can be retrieved the same way,
复制代码
使用配置

经过以上配置, 在项目中就可以通过 @Configuration 获取 Consul 中配置的信息
  1. @Slf4j
  2. @Configuration
  3. public class CommonConfig {
  4.     @Value("${common.name}")
  5.     private String name = "Dummy";
  6.     @Value("${common.code}")
  7.     private String code = "001";
  8.     public String getName() {return name;}
  9.     public void setName(String name) {this.name = name;}
  10.     public String getCode() {return code;}
  11.     public void setCode(String code) {this.code = code;}
  12.     @PostConstruct
  13.     public void postConstruct() {
  14.         log.info("name: {}", name);
  15.         log.info("code: {}", code);
  16.     }
  17. }
复制代码
参考


免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!




欢迎光临 ToB企服应用市场:ToB评测及商务社交产业平台 (https://dis.qidao123.com/) Powered by Discuz! X3.4