SpringCloud-Config分布式配置中心的简单实现

SpringCloud-Config个人理解

SpringCloud-Config:是分布式配置中心,当很多的微服务架构使用的是同一套配置时,如果要进行修改就会发生很多的重复操作。耦合太高,所以一套配置处处生效的SpringCloud-Config分布式配置就可以省下很多的重复操作。

这边是服务端(server)

首先是需要导入的pom包:

<dependencies>
        <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>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-actuator</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-devtools</artifactId>
            <scope>runtime</scope>
            <optional>true</optional>
        </dependency>
        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <optional>true</optional>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>
    </dependencies>

其中spring-cloud-config-server是配置分布式配置中心的关键

这里拿出spring-cloud来说
我们要登录Github来创建一个仓库,

在master分支下创建几个测试的yml文件,我起名为config-dev和config-text文件
下面是config-dev中的内容
在这里插入图片描述

config:
  info: "master branch,spring-cloud-git/config-dev.yml,version=1"

注意最好先下载一个git软件在自己本地电脑clone一份代码下来
再生成自己的SSH私钥绑定在github上面,这样可以直接不需要验证直接登录

再就是配置application.yml

server:
  port: 3344
spring:
  application:
    name: cloud-config-center
  cloud:
    config:
      server:
        git:
          uri: https://github.com/baby0o0/spring-cloud-git.git #这里是链接Github仓库的链接
          search-paths:
            - spring-cloud-git #这里是仓库名
      label: master #这里是链接仓库的分支
eureka:
  client:
    service-url:
      defaultZone: http://eureka7001.com:7001/eureka/,http://eureka7002.com:7002/eureka/

之后就是配置main方法,使用@EnableConfigServer注解

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

服务端(server)就到此配置完成

客户端(client)开始配置

首先就是pom

    <dependencies>
        <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>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-actuator</artifactId>
        </dependency>

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-devtools</artifactId>
            <scope>runtime</scope>
            <optional>true</optional>
        </dependency>
        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <optional>true</optional>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>
    </dependencies>

可以看到配置Config的spring-cloud-starter-config和之前服务端的spring-cloud-config-server不同
之后是配置bootstrap.yml
这里解释一下为什么是bootstrap.yml而不是application.yml

bootstrap.yml(bootstrap.properties)在application.yml(application.properties)之前加载,就像application.yml一样,但是用于应用程序上下文的引导阶段。

首先会应用bootstrap加载配置,获取配置环境后再用application进行配置。而我们分布式配置自然要先获取外部全局配置再和自己个人的application进行结合,所以在bootstrap当中配置。

server:
  port:
    3355
spring:
  application:
    name: config-client
  cloud:
    config:
      label: master #在哪个分支下获取
      name: config #获取的application前缀
      profile: dev #获取的application后缀
      uri: http://localhost:3344 #获取配置的url

eureka:
  client:
    service-url:
      defaultZone: http://eureka7001.com:7001/eureka/,http://eureka7002.com:7002/eureka/

之后配置main方法

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

创建一个ConfigClientController来获取配置

@RestController
@Slf4j
public class ConfigClientController {
    @Value("${config.info}")
    private String configInfo;

    @GetMapping(value = "/configInfo")
    public String getConfigInfo(){
        return configInfo;
    }
}

这里可以直接运行配置中心,再是server端最后client端。
但是这样会有个问题,当运维修改的github的具体数据比如我把config-dev当中的配置版本号改为2

config:
  info: "master branch,spring-cloud-git/config-dev.yml,version=2"

server端会直接获取
在这里插入图片描述

但是在client端并没有获取到最新消息
在这里插入图片描述
在这里我们就需要对client端进行一些改造使他不经过重启也可以获取最新配置。
首先我们需要对bootstrap添加下面一段代码

management:
  endpoints:
    web:
      exposure:
        include: "*"

这是提示在获取配置时把web端所含的配置全部暴露,
之后在controller端添加@RefreshScope注解

@RestController
@Slf4j
@RefreshScope
public class ConfigClientController {
    @Value("${config.info}")
    private String configInfo;

    @GetMapping(value = "/configInfo")
    public String getConfigInfo(){
        return configInfo;
    }
}

在这样配置完成之后发现client端还是没有获取到最新配置
于是我们需要有最新的配置时,我们需要post访问client端对应端口的/actuator/refresh
如下
http://localhost:3355/actuator/refresh
我用postman访问得
在这里插入图片描述
这样client端就可以获取最新配置了
但是如果服务端多而且要部分获取新配置这样手动获取就很麻烦,之后的消息总线可以解决这个问题
SpringCloud-Config到此结束

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值