原文链接:spring cloud(七) config配置中心 – 每天进步一点点
0.简介
![]()
前面的文章我们创建了很多微服务,每个微服务都需要自己的配置才能运行,每个服务都有自己配置文件,微服务多了配置文件就多了,如果要修改某一个参数,就需要修改多个微服务的配置文件。为了解决这个问题,Spring Cloud提供了一个解决方案就是使用spring cloud config分布式配置中心来做到一处修改,处处运行。
![]()
整个流程可以分成三大步骤:
(1)首先搭建一个远程仓库(github、gitlab、码云都行,本文使用码云做演示),然后创建一个项目,命名为spring-cloud-config (名称无所谓),然后把这个仓库克隆到本地。
(2)然后搭建配置中心的服务端
(3)最后搭建配置中心的客户端
官方文档:https://docs.spring.io/spring-cloud-config/docs/current/reference/html/
(注:后面可以用nacos代替,nacos=spring cloud eureka+spring cloud config + spring cloud bus)
1.搭建远程仓库
我们打开码云,创建一个仓库。
注意,仓库最好设置成公开,如果设置成私有,下面的配置信息需要加上仓库的用户名和密码。
![]()
然后把仓库克隆到本地,然后我们创建一个测试文件,里面放置一个简单文件如下:
1
2
|
config:
info: "hello,config!"
|
并命名为:config-test.yml。然后把这个文件上传到到码云上。
![]()
![]()
这样git仓库部分就搭建完毕了,后期可以往仓库里添加其他配置文件了。
注意: 统一配置中心服务端 config Server 读取远程仓储的配置的时候是有一定的规则,因此在远程仓储中的配置文件命名也要有一定的规则。
远程仓库配置文件命名规则:
1
|
{application}-{profile}.yml/{application}-{profile}.properties
|
config server 读取远程仓库的配置规则:
1
2
3
4
5
|
/{application}/{profile}[/{label}]
/{application}-{profile}.yml
/{label}/{application}-{profile}.yml
/{application}-{profile}.properties
/{label}/{application}-{profile}.properties
|
其中,label代表的是分支,profile代表的是环境。
2.搭建配置服务中心服务端
我们参考前面的文章, 创建一个module,
POM文件如下:
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<artifactId>s-cloud</artifactId>
<groupId>site.longkui</groupId>
<version>0.0.1-SNAPSHOT</version>
<modelVersion>4.0.0</modelVersion>
<artifactId>s-cloud-config</artifactId>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
<!-- 添加统一服务配置中心 config-->
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-config-server</artifactId>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
<version>3.1.8-SNAPSHOT</version>
配置文件application.yml参考如下(这里增加了git的配置):
name: service-config #服务的名称
skip-ssl-validation: true #跳过ssl认证
uri: https://gitee.com/guo1635/spring-cloud-config.git #要读取的远程仓库的配置文件的地址。
default-label: master # 指定分支,不指定则默认master
defaultZone: http://localhost:7001/eureka
register-with-eureka: true
instance-id: 𝑠𝑝𝑟𝑖𝑛𝑔.𝑐𝑙𝑜𝑢𝑑.𝑐𝑙𝑖𝑒𝑛𝑡.𝑖𝑝−𝑎𝑑𝑑𝑟𝑒𝑠𝑠:{server.port}
创建启动类参考如下,注意,这里加入了@EnableConfigServer 注解,表示spring-cloud-config的服务端
package site.longkui.scloudconfig;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.config.server.EnableConfigServer;
import org.springframework.cloud.netflix.eureka.EnableEurekaClient;
@EnableEurekaClient// eureka 客户端
@EnableConfigServer// config 服务端
public class sCloudConfig {
public static void main(String[] args) {
SpringApplication.run(sCloudConfig.class, args);
然后我们访问我们的测试文件的地址:
http://localhost:20000/master/config-test.yml
![]()
可以看到,正常获取我们创建的测试配置文件。我们修改码云上的配置文件后,刷新后也可以得到最新的配置信息。
![]()
3.搭建配置服务中心客户端
客户端的POM文件参考如下:
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<artifactId>s-cloud</artifactId>
<groupId>site.longkui</groupId>
<version>0.0.1-SNAPSHOT</version>
<modelVersion>4.0.0</modelVersion>
<artifactId>s-cloud-config-clinent</artifactId>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-config</artifactId>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
<version>3.1.8-SNAPSHOT</version>
<!-- 新版本的springcloud不支持bootstrap.yml,需要引入下面的依赖 -->
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-bootstrap</artifactId>
新建配置文件,bootstrap.yml,详细原因可以看:https://www.longkui.site/program/java/application-bootstrap/5060/
简单来说就是bootstrap.yml的优先级比application.yml优先级高。
name: service-config-client #服务的名称
uri: http://127.0.0.1:20000 #配置中心地址
defaultZone: http://localhost:7001/eureka
register-with-eureka: true
instance-id: 𝑠𝑝𝑟𝑖𝑛𝑔.𝑐𝑙𝑜𝑢𝑑.𝑐𝑙𝑖𝑒𝑛𝑡.𝑖𝑝−𝑎𝑑𝑑𝑟𝑒𝑠𝑠:{server.port}
![]()
我们配置测试配置文件config-test.yml,这里的name对应的是文件名的前面部分,profile对应的是后面部分。
注意,上面这里用的IP地址+端口的方式进行的访问,实际操作中,更多的是用服务的方式进行访问,参考如下:
![]()
name: service-config-client #服务的名称
service-id: service-config #告诉当前客户端 统一配置中心的服务端服务id
enabled: true #开启客户端,根据服务id到注册中心获取配置信息
# uri: http://127.0.0.1:20000 #配置中心地址
defaultZone: http://localhost:7001/eureka
register-with-eureka: true
instance-id: ${spring.cloud.client.ip-address}:${server.port}
创建启动类:
package site.longkui.scloudconfigclient;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.netflix.eureka.EnableEurekaClient;
@EnableEurekaClient// eureka 客户端
public class sCloudConfigClient {
public static void main(String[] args) {
SpringApplication.run(sCloudConfigClient.class, args);
创建controller
package site.longkui.scloudconfigclient.controller;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
@RequestMapping("/config")
public class ConfigClientController {
@GetMapping("/getConfig")
public String getConfig(){
然后启动模块,访问我们的接口,可以看到,能够正确读取配置内容。
![]()
4.客户端手动刷新
客户端需要动态刷新的原因,请看下图:
![]()
我们修改了配置,不能立即在客户端生效,需要重新启动才能生效。
我们可以通过手动刷新和自动刷新来解决这个问题。
我们在客户端添加一个依赖
![]()
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-actuator</artifactId>
对外暴露服务端点,让客户端可以接受到配置的更新,我们修改客户端的bootstrap.yml
#暴露服务端点,让客户端能感受到配置的更新
management:
endpoints:
web:
exposure:
include: "*"
然后在controller中加入@RefeshScope
package site.longkui.scloudconfigclient.controller;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.cloud.context.config.annotation.RefreshScope;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
@RequestMapping("/config")
public class ConfigClientController {
@GetMapping("/getConfig")
public String getConfig(){
然后重启模块,此时修改配置后,需要在CMD中访问以下地址。
curl -X POST "http://127.0.0.1:30000/actuator/refresh
然后再访问客户端就可以手动刷新了。
![]()
自动刷新将在下一篇bus消息总线进行介绍。