Spring Cloud(十六):Config分布式配置中心

落日映苍穹つ 2022-11-13 06:21 229阅读 0赞

1. 概述

1.1 分布式系统面临的配置问题

微服务意味着要将单体应用的业务拆分成一个个子服务,每个服务的粒度相对较小,因此系统中会出现大量的服务。由于每个服务都需要必要的配置信息才能运行,所以一套集中式的、动态的配置管理设施是必不可少的。

Spring Cloud 提供了ConfigServer来解决这个问题。

1.2 是什么

在这里插入图片描述
Spring Cloud Config为微服务架构中的微服务提供集中化的外部配置支持,配置服务器为各个不同的微服务应用的所有环境提供了一个中心化的外部配置。

Spring Cloud Config 分为服务端和客户端两部分。

服务端也称为分布式配置中心,它是一个独立的微服务应用,用来连接配置服务器并为客户端提供获取配置信息,加密/解密信息等访问接口。

客户端则是通过指定的配置中心来管理应用资源,以及与业务相关的配置内容,并在启动的时候从配置中心来获取和加载配置信息。配置服务器默认采用git来存储配置信息,这样就有助于对环境配置进行版本管理,并且通过git客户端工具来方便的管理和访问配置内容。

1.3 能干嘛

  • 集中管理配置文件
  • 不同环境不同配置,动态化的配置更新,分环境部署比如dev/test/prod/beta/release
  • 运行期间动态调整配置,不再需要在每个服务部署的机器上编写配置文件,服务会向配置中心统一拉取配置自己的信息
  • 当配置发生变动时,服务不需要重启即可感知到配置的变化并应用新的配置
  • 将配置信息以REST接口的形式暴露post、curl访问刷新均可…

2. 与 Gitee 整合

由于SpringCloud Config默认使用Git来存储配置文件(也有其它方式,比如支持svn和本地文件,但最推荐的还是Git,而且使用的是http/https访问的形式)

2.1 Config服务端配置与测试

在Gitee上新建一个名为spring-cloud-config的新Repository在里面新建yml
在这里插入图片描述

3. 添加 Config 模块

3.1 新建 module

新建Module模块cloud-config-center-3344它既为Cloud的配置中心模块

3.2 pom

  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <project xmlns="http://maven.apache.org/POM/4.0.0"
  3. xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  4. xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
  5. <parent>
  6. <artifactId>spring-cloud-demo</artifactId>
  7. <groupId>com.lele.springcloud</groupId>
  8. <version>1.0-SNAPSHOT</version>
  9. </parent>
  10. <modelVersion>4.0.0</modelVersion>
  11. <artifactId>cloud-config-center-3344</artifactId>
  12. <dependencies>
  13. <dependency>
  14. <groupId>org.springframework.cloud</groupId>
  15. <artifactId>spring-cloud-config-server</artifactId>
  16. </dependency>
  17. <dependency>
  18. <groupId>org.springframework.cloud</groupId>
  19. <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
  20. </dependency>
  21. <dependency>
  22. <groupId>org.springframework.boot</groupId>
  23. <artifactId>spring-boot-starter-web</artifactId>
  24. </dependency>
  25. <dependency>
  26. <groupId>org.springframework.boot</groupId>
  27. <artifactId>spring-boot-starter-actuator</artifactId>
  28. </dependency>
  29. <dependency>
  30. <groupId>org.springframework.boot</groupId>
  31. <artifactId>spring-boot-devtools</artifactId>
  32. <scope>runtime</scope>
  33. <optional>true</optional>
  34. </dependency>
  35. <dependency>
  36. <groupId>org.projectlombok</groupId>
  37. <artifactId>lombok</artifactId>
  38. <optional>true</optional>
  39. </dependency>
  40. <dependency>
  41. <groupId>org.springframework.boot</groupId>
  42. <artifactId>spring-boot-starter-test</artifactId>
  43. <scope>test</scope>
  44. </dependency>
  45. </dependencies>
  46. </project>

3.3 yml

  1. server:
  2. port: 3344
  3. spring:
  4. application:
  5. name: cloud-config-center
  6. cloud:
  7. config:
  8. server:
  9. git:
  10. uri: https://gitee.com/houwanle/spring-cloud-config.git #gittee上的仓库名称
  11. username: houwanle
  12. password: lele1995@gitee
  13. # 搜索目录
  14. search-paths:
  15. - spring-cloud-config
  16. #读取分支
  17. label: master
  18. #服务注册到eureka地址
  19. eureka:
  20. client:
  21. service-url:
  22. defaultZone: http://localhost:7001/eureka

3.4 主启动类

  1. package com.lele.springcloud;
  2. import org.springframework.boot.SpringApplication;
  3. import org.springframework.boot.autoconfigure.SpringBootApplication;
  4. import org.springframework.cloud.config.server.EnableConfigServer;
  5. /**
  6. * @author: lele
  7. * @date: 2021/3/30 7:29
  8. * @description:
  9. */
  10. @SpringBootApplication
  11. @EnableConfigServer
  12. public class ConfigCenterMain3344 {
  13. public static void main(String[] args) {
  14. SpringApplication.run(ConfigCenterMain3344.class, args);
  15. }
  16. }

windows下修改hosts文件,增加映射:
在这里插入图片描述

测试通过Config微服务是否可以从gittee上获取配置内容

  • 启动微服务3344
  • http://config-3344.com:3344/master/config-dev.yml
    在这里插入图片描述

3.5 配置读取规则

官网

在这里插入图片描述

/{label}/{application}-{profile}.yml(最推荐使用这种方式)

  • master分支
    http://config-3344.com:3344/master/config-dev.yml
  • dev分支
    http://config-3344.com:3344/dev/config-dev.yml

重要配置细节总结
/{name}={profiles}.yml
/{label}-{name}-{profiles}.yml

  • label:分支
  • name:服务名
  • profiles:环境(dev/test/prod)

4. Config客户端配置与测试

4.1 新建 module

新建cloud-config-client-3355

4.2 pom

  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <project xmlns="http://maven.apache.org/POM/4.0.0"
  3. xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  4. xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
  5. <parent>
  6. <artifactId>spring-cloud-demo</artifactId>
  7. <groupId>com.lele.springcloud</groupId>
  8. <version>1.0-SNAPSHOT</version>
  9. </parent>
  10. <modelVersion>4.0.0</modelVersion>
  11. <artifactId>cloud-config-client-3355</artifactId>
  12. <dependencies>
  13. <dependency>
  14. <groupId>org.springframework.cloud</groupId>
  15. <artifactId>spring-cloud-starter-config</artifactId>
  16. </dependency>
  17. <dependency>
  18. <groupId>org.springframework.cloud</groupId>
  19. <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
  20. </dependency>
  21. <dependency>
  22. <groupId>org.springframework.boot</groupId>
  23. <artifactId>spring-boot-starter-web</artifactId>
  24. </dependency>
  25. <dependency>
  26. <groupId>org.springframework.boot</groupId>
  27. <artifactId>spring-boot-starter-actuator</artifactId>
  28. </dependency>
  29. <dependency>
  30. <groupId>org.springframework.boot</groupId>
  31. <artifactId>spring-boot-devtools</artifactId>
  32. <scope>runtime</scope>
  33. <optional>true</optional>
  34. </dependency>
  35. <dependency>
  36. <groupId>org.projectlombok</groupId>
  37. <artifactId>lombok</artifactId>
  38. <optional>true</optional>
  39. </dependency>
  40. <dependency>
  41. <groupId>org.springframework.boot</groupId>
  42. <artifactId>spring-boot-starter-test</artifactId>
  43. <scope>test</scope>
  44. </dependency>
  45. </dependencies>
  46. </project>

4.3 yml

application.yml是用户级的资源配置项
boostrap.yml 是系统级的,优先级更高

Spring Cloud 会创建一个“Boostrap Context”,作为Spring应用的“Application Context” 的父上下文。初始化的时候,“Boostarp Context” 负责从外部源加载配置属性并解析配置。这两个上下文共享一个从外部获取的“Environment”

“Bootstrap” 属性有高优先级,默认情况下,他们不会被本地配置覆盖。“Boostarp Context” 和“Application Context” 有着不同的约定,所以新增了一个“boostarp.yml文件”,保证“Boostarp Context” 和“Application Context” 配置的分离

要将Client模块下的application.yml 改为 boostrap.yml

  • bootstrap.yml

    server:
    port: 3355

    spring:
    application:

    1. name: config-client

    cloud:

    1. #Config客户端配置
    2. config:
    3. label: master #分支名称
    4. name: config #配置文件名称
    5. profile: dev #读取后缀名称 上述3个综合:master分支上config-dev.yml的配置文件被读取 http://config-3344.com:3344/master/config-dev.yml
    6. uri: http://localhost:3344 #配置中心地址

    服务注册到Eureka地址

    eureka:
    client:

    1. service-url:
    2. defaultZone: http://localhost:7001/eureka

4.4 主启动类

  • 主启动类

    package com.lele.springcloud;

    import org.springframework.boot.SpringApplication;
    import org.springframework.boot.autoconfigure.SpringBootApplication;
    import org.springframework.cloud.netflix.eureka.EnableEurekaClient;

    /**

    • @author: lele
    • @date: 2021/3/31 7:13
    • @description:
      */
      @SpringBootApplication
      @EnableEurekaClient
      public class ConfigClientMain3355 {

      public static void main(String[] args) {

      1. SpringApplication.run(ConfigClientMain3355.class, args);

      }
      }

  • 业务类

    package com.lele.springcloud.controller;

    import org.springframework.beans.factory.annotation.Value;
    import org.springframework.web.bind.annotation.GetMapping;
    import org.springframework.web.bind.annotation.RestController;

    /**

    • @author: lele
    • @date: 2021/3/31 7:17
    • @description:
      */
      @RestController
      public class ConfigClientController {
  1. @Value("${config.info}")
  2. private String configInfo;
  3. @GetMapping("/configInfo")
  4. public String getConfigInfo() {
  5. return configInfo;
  6. }
  7. }

启动Config配置中心3344微服务并自测
http://config-3344.com:3344/master/config-dev.yml
在这里插入图片描述

在这里插入图片描述

5. Config客户端之动态刷新

但是此时如果修改git上的配置文件,只有3344会动态获取 3355则需要重启才可以获取最新的配置

避免每次更新配置都要重启客户端微服务3355

  • 3355,POM引入actuator监控


    org.springframework.boot
    spring-boot-starter-actuator
  • 修改YML,暴露监控端口

    server:
    port: 3355

    spring:
    application:

    1. name: config-client

    cloud:

    1. #Config客户端配置
    2. config:
    3. label: master #分支名称
    4. name: config #配置文件名称
    5. profile: dev #读取后缀名称 上述3个综合:master分支上config-dev.yml的配置文件被读取 http://config-3344.com:3344/master/config-dev.yml
    6. uri: http://localhost:3344 #配置中心地址

    服务注册到Eureka地址

    eureka:
    client:

    1. service-url:
    2. defaultZone: http://localhost:7001/eureka
  1. management:
  2. endpoints:
  3. web:
  4. exposure:
  5. include: "*"
  • @RefreshScope业务类Controller修改
    在这里插入图片描述
  • 发送Post请求刷新3355
    curl -X POST “http://localhost:3355/actuator/refresh”
    在这里插入图片描述

此时还有一个问题如果有多个微服务客户端,每个微服务都要执行一次post请求,手动刷新。可否广播,一次通知处处生效?需要引入SpringCloud Bus 消息总线来解决这一问题。

发表评论

表情:
评论列表 (有 0 条评论,229人围观)

还没有评论,来说两句吧...

相关阅读