2023-02-21  阅读(2)
原文作者:macrozheng 原文地址:https://www.macrozheng.com/cloud/cloud_catalog.html

# Spring Cloud Config:外部集中化配置管理

Spring Cloud Config 可以为微服务架构中的应用提供集中化的外部配置支持,它分为服务端和客户端两个部分,本文将对其用法进行详细介绍。

# Spring Cloud Config 简介

Spring Cloud Config 分为服务端和客户端两个部分。服务端被称为分布式配置中心,它是个独立的应用,可以从配置仓库获取配置信息并提供给客户端使用。客户端可以通过配置中心来获取配置信息,在启动时加载配置。Spring Cloud Config 的配置中心默认采用Git来存储配置信息,所以天然就支持配置信息的版本管理,并且可以使用Git客户端来方便地管理和访问配置信息。

# 在Git仓库中准备配置信息

由于Spring Cloud Config 需要一个存储配置信息的Git仓库,这里我们先在Git仓库中添加好配置文件再演示其功能,Git仓库地址为:https://gitee.com/macrozheng/springcloud-configopen in new window

# 配置仓库目录结构

202302212302408481.png

# master分支下的配置信息

  • config-dev.yml:
    config:
      info: "config info for dev(master)"
  • config-test.yml:
    config:
      info: "config info for test(master)"
  • config-prod.yml:
    config:
      info: "config info for prod(master)"

# dev分支下的配置信息

  • config-dev.yml:
    config:
      info: "config info for dev(dev)"
  • config-test.yml:
    config:
      info: "config info for test(dev)"
  • config-prod.yml:
    config:
      info: "config info for prod(dev)"

# 创建config-server模块

这里我们创建一个config-server模块来演示Spring Cloud Config 作为配置中心的功能。

# 在pom.xml中添加相关依赖

    <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-config-server</artifactId>
    </dependency>
    <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
    </dependency>

# 在application.yml中进行配置

    server:
      port: 8901
    spring:
      application:
        name: config-server
      cloud:
        config:
          server:
            git: #配置存储配置信息的Git仓库
              uri: https://gitee.com/macrozheng/springcloud-config.git
              username: macro
              password: 123456
              clone-on-start: true #开启启动时直接从git获取配置
    eureka:
      client:
        service-url:
          defaultZone: http://localhost:8001/eureka/

# 在启动类上添加@EnableConfigServer注解来启用配置中心功能

    @EnableConfigServer
    @EnableDiscoveryClient
    @SpringBootApplication
    public class ConfigServerApplication {
    
        public static void main(String[] args) {
            SpringApplication.run(ConfigServerApplication.class, args);
        }
    
    }

# 通过config-server获取配置信息

这里我们通过config-server来演示下如何获取配置信息。

# 获取配置文件信息的访问格式

    # 获取配置信息
    /{label}/{application}-{profile}
    # 获取配置文件信息
    /{label}/{application}-{profile}.yml

# 占位符相关解释

  • application:代表应用名称,默认为配置文件中的spring.application.name,如果配置了spring.cloud.config.name,则为该名称;
  • label:代表分支名称,对应配置文件中的spring.cloud.config.label;
  • profile:代表环境名称,对应配置文件中的spring.cloud.config.profile。

# 获取配置信息演示

202302212302418302.png

202302212302426823.png

202302212302432764.png

202302212302439355.png

# 创建config-client模块

我们创建一个config-client模块来从config-server获取配置。

# 在pom.xml中添加相关依赖

    <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-starter-config</artifactId>
    </dependency>
    <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
    </dependency>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-web</artifactId>
    </dependency>

# 在bootstrap.yml中进行配置

    server:
      port: 9001
    spring:
      application:
        name: config-client
      cloud:
        config: #Config客户端配置
          profile: dev #启用配置后缀名称
          label: dev #分支名称
          uri: http://localhost:8901 #配置中心地址
          name: config #配置文件名称
    eureka:
      client:
        service-url:
          defaultZone: http://localhost:8001/eureka/

# 添加ConfigClientController类用于获取配置

    /**
     * Created by macro on 2019/9/11.
     */
    @RestController
    public class ConfigClientController {
    
        @Value("${config.info}")
        private String configInfo;
    
        @GetMapping("/configInfo")
        public String getConfigInfo() {
            return configInfo;
        }
    }

# 演示从配置中心获取配置

    config info for dev(dev)

# 获取子目录下的配置

我们不仅可以把每个项目的配置放在不同的Git仓库存储,也可以在一个Git仓库中存储多个项目的配置,此时就会用到在子目录中搜索配置信息的配置。

  • 首先我们需要在config-server中添加相关配置,用于搜索子目录中的配置,这里我们用到了application占位符,表示对于不同的应用,我们从对应应用名称的子目录中搜索配置,比如config子目录中的配置对应config应用;
    spring:
      cloud:
        config:
          server:
            git: 
              search-paths: '{application}'
    config info for config dir dev(dev)

# 刷新配置

当Git仓库中的配置信息更改后,我们可以通过SpringBoot Actuator的refresh端点来刷新客户端配置信息,以下更改都需要在config-client中进行。

  • 在pom.xml中添加Actuator的依赖:
    <dependency>
       <groupId>org.springframework.boot</groupId>
       <artifactId>spring-boot-starter-actuator</artifactId>
    </dependency>
  • 在bootstrap.yml中开启refresh端点:
    management:
      endpoints:
        web:
          exposure:
            include: 'refresh'
  • 在ConfigClientController类添加@RefreshScope注解用于刷新配置:
    /**
     * Created by macro on 2019/9/11.
     */
    @RestController
    @RefreshScope
    public class ConfigClientController {
    
        @Value("${config.info}")
        private String configInfo;
    
        @GetMapping("/configInfo")
        public String getConfigInfo() {
            return configInfo;
        }
    }
  • 重新启动config-client后,调用refresh端点进行配置刷新:

202302212302447456.png

    update config info for config dir dev(dev)

# 配置中心添加安全认证

我们可以通过整合SpringSecurity来为配置中心添加安全认证。

# 创建config-security-server模块

  • 在pom.xml中添加相关依赖:
    <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-config-server</artifactId>
    </dependency>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-security</artifactId>
    </dependency>
  • 在application.yml中进行配置:
    server:
      port: 8905
    spring:
      application:
        name: config-security-server
      cloud:
        config:
          server:
            git:
              uri: https://gitee.com/macrozheng/springcloud-config.git
              username: macro
              password: 123456
              clone-on-start: true #开启启动时直接从git获取配置
      security: #配置用户名和密码
        user:
          name: macro
          password: 123456
  • 启动config-security-server服务。

# 修改config-client的配置

  • 添加bootstrap-security.yml配置文件,主要是配置了配置中心的用户名和密码:
    server:
      port: 9002
    spring:
      application:
        name: config-client
      cloud:
        config:
          profile: dev #启用配置后缀名称
          label: dev #分支名称
          uri: http://localhost:8905 #配置中心地址
          name: config #配置文件名称
          username: macro
          password: 123456
    config info for dev(dev)

# config-sever集群搭建

在微服务架构中,所有服务都从配置中心获取配置,配置中心一旦宕机,会发生很严重的问题,下面我们搭建一个双节点的配置中心集群来解决该问题。

  • 启动两个config-server分别运行在8902和8903端口上;
  • 添加config-client的配置文件bootstrap-cluster.yml,主要是添加了从注册中心获取配置中心地址的配置并去除了配置中心uri的配置:
    spring:
      cloud:
        config:
          profile: dev #启用环境名称
          label: dev #分支名称
          name: config #配置文件名称
          discovery:
            enabled: true
            service-id: config-server
    eureka:
      client:
        service-url:
          defaultZone: http://localhost:8001/eureka/
  • 以bootstrap-cluster.yml启动config-client服务,注册中心显示信息如下:

202302212302455477.png

    config info for config dir dev(dev)

# 使用到的模块

    springcloud-learning
    ├── eureka-server -- eureka注册中心
    ├── config-server -- 配置中心服务
    ├── config-security-server -- 带安全认证的配置中心服务
    └── config-client -- 获取配置的客户端服务

# 项目源码地址

https://github.com/macrozheng/springcloud-learningopen in new window


Java 面试宝典是大明哥全力打造的 Java 精品面试题,它是一份靠谱、强大、详细、经典的 Java 后端面试宝典。它不仅仅只是一道道面试题,而是一套完整的 Java 知识体系,一套你 Java 知识点的扫盲贴。

它的内容包括:

  • 大厂真题:Java 面试宝典里面的题目都是最近几年的高频的大厂面试真题。
  • 原创内容:Java 面试宝典内容全部都是大明哥原创,内容全面且通俗易懂,回答部分可以直接作为面试回答内容。
  • 持续更新:一次购买,永久有效。大明哥会持续更新 3+ 年,累计更新 1000+,宝典会不断迭代更新,保证最新、最全面。
  • 覆盖全面:本宝典累计更新 1000+,从 Java 入门到 Java 架构的高频面试题,实现 360° 全覆盖。
  • 不止面试:内容包含面试题解析、内容详解、知识扩展,它不仅仅只是一份面试题,更是一套完整的 Java 知识体系。
  • 宝典详情:https://www.yuque.com/chenssy/sike-java/xvlo920axlp7sf4k
  • 宝典总览:https://www.yuque.com/chenssy/sike-java/yogsehzntzgp4ly1
  • 宝典进展:https://www.yuque.com/chenssy/sike-java/en9ned7loo47z5aw

目前 Java 面试宝典累计更新 400+ 道,总字数 42w+。大明哥还在持续更新中,下图是大明哥在 2024-12 月份的更新情况:

想了解详情的小伙伴,扫描下面二维码加大明哥微信【daming091】咨询

同时,大明哥也整理一套目前市面最常见的热点面试题。微信搜[大明哥聊 Java]或扫描下方二维码关注大明哥的原创公众号[大明哥聊 Java] ,回复【面试题】 即可免费领取。

阅读全文