Spring Cloud 之Config详解

在微服务架构中,统一的配置管理是维护大规模分布式系统的关键。Spring Cloud Config为微服务提供集中化的外部配置支持,它可以与各种源代码管理系统集成,如Git、SVN等。本文将详细介绍如何搭建配置服务器、管理客户端配置和动态刷新配置。

搭建配置服务器

基本原理

Spring Cloud Config Server作为中心化的配置服务器,它从源代码管理系统中读取配置文件,然后提供给客户端应用。原理图如下:

步骤和代码

  1. 添加依赖 :在项目的pom.xml文件中添加Config Server的依赖。

    xml 复制代码
    <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-config-server</artifactId>
    </dependency>
  2. 启用Config Server :在应用的主类上添加@EnableConfigServer注解。

    less 复制代码
    @SpringBootApplication
    @EnableConfigServer
    public class ConfigServerApplication {
        public static void main(String[] args) {
            SpringApplication.run(ConfigServerApplication.class, args);
        }
    }
  3. 配置文件 :在application.yml中配置Git仓库地址。

    yaml 复制代码
    server:
      port: 8888
    
    spring:
      cloud:
        config:
          server:
            git:
              uri: [Git仓库地址]
              clone-on-start: true

客户端配置管理

配置客户端

  1. 添加依赖 :在客户端应用的pom.xml中添加Config Client的依赖。

    xml 复制代码
    <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-starter-config</artifactId>
    </dependency>
  2. 配置bootstrap.yml :客户端应用需要在bootstrap.yml文件中指定Config Server的地址。

    yaml 复制代码
    spring:
      application:
        name: client-app
      cloud:
        config:
          uri: http://localhost:8888

读取配置

在客户端应用中,可以直接通过@Value注解读取配置:

kotlin 复制代码
@RestController
public class ConfigClientController {

    @Value("${some.config}")
    private String someConfig;

    @GetMapping("/getConfig")
    public String getConfig() {
        return someConfig;
    }
}

动态刷新配置

Spring Cloud Config支持在不重启服务的情况下刷新配置。

  1. 添加依赖 :在客户端应用中添加spring-boot-starter-actuator依赖。

    xml 复制代码
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-actuator</artifactId>
    </dependency>
  2. 使用@RefreshScope :在需要动态刷新的Bean上添加@RefreshScope注解。

    less 复制代码
    @RestController
    @RefreshScope
    public class ConfigClientController {
        // ...
    }
  3. 触发刷新 :通过POST请求/actuator/refresh端点来刷新配置。

    bash 复制代码
    curl -X POST http://localhost:8080/actuator/refresh

通过上述内容,我们对Spring Cloud Config的配置服务器搭建、客户端配置管理和动态刷新配置有了深入的了解。Spring Cloud Config为微服务架构中的配置管理提供了一个简单、灵活且强大的解决方案。

相关推荐
bobz9652 小时前
小语言模型是真正的未来
后端
DevYK3 小时前
企业级 Agent 开发实战(一) LangGraph 快速入门
后端·llm·agent
一只叫煤球的猫3 小时前
🕰 一个案例带你彻底搞懂延迟双删
java·后端·面试
冒泡的肥皂4 小时前
MVCC初学demo(一
数据库·后端·mysql
颜如玉4 小时前
ElasticSearch关键参数备忘
后端·elasticsearch·搜索引擎
卡拉叽里呱啦5 小时前
缓存-变更事件捕捉、更新策略、本地缓存和热key问题
分布式·后端·缓存
David爱编程5 小时前
线程调度策略详解:时间片轮转 vs 优先级机制,面试常考!
java·后端
码事漫谈6 小时前
C++继承中的虚函数机制:从单继承到多继承的深度解析
后端
阿冲Runner6 小时前
创建一个生产可用的线程池
java·后端
写bug写bug6 小时前
你真的会用枚举吗
java·后端·设计模式