第七节:高可用的分布式配置中心(Spring Cloud Config)

一、基本架构

        读了方老师的文章:第七篇: 高可用的分布式配置中心(Spring Cloud Config)(Finchley版本),确实很有收获,特别是架构图可以一目了然。上一篇只是单纯的让某个配置中心从GIT上获取配置文件,然后有一个客户端Client使用从GIT上的配置文件。但是随着服务的增多,如果都使用同一个配置中心,万一此配置中心挂了,那么依赖此配置中心的所有微服务系统就全部崩溃了。所以,为了避免这种情况的出现,那么就部署多个配置中心,防止某个配置中心节点故障导致的整个系统的崩溃的情况。因此,需要把配置中心与微服务Client 都注册到 注册中心中统一管理。

        通读方老师的这篇文章,可以知道的是,将配置中心与微服务Client都作为Eureka的Client。但是如何将多个ServiceClient通过负载均衡技术,负载到不同的配置中心中,方老师并没有提及。其实方老师提供的是一种搭建高可用的分布式配置中心的思路,还是很值得借鉴的。当然了,如此高深的技术,博主肯定也不会啦o(╥﹏╥)o

Azure (3).png

二、搭建注册中心

        在上一节的代码上,增加一个注册中心模块。

        右击项目根目录,New--Module--选择左侧的Maven,点击next--输入新模块的名字eureka-server

        2.1  导入依赖

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

    </dependencies>

        2.2  编写application.yml

        我喜欢把注册中心放到8761端口。

server:
  port: 8761

eureka:
  instance:
    hostname: localhost
  client:
    registerWithEureka: false
    fetchRegistry: false
    serviceUrl:
      defaultZone: http://${eureka.instance.hostname}:${server.port}/eureka/

        2.3  编写启动类

        准确的说,搭建一个注册中心,与以前的步骤没有任何区别。

package com.safesoft.register;

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

/**
 * @author jay.zhou
 * @date 2019/1/27
 * @time 16:05
 */
@EnableEurekaServer
@SpringBootApplication
public class ApplicationServer {
    public static void main(String[] args) {
        SpringApplication.run(ApplicationServer.class, args);
    }
}

三、改造配置中心

        从第一节中的分析知道,为了搭建高可用的分布式配置中心,那么就需要把配置中心加入注册中心中统一管理。

        其实思路很简单,就是把配置中心也当成一个Eureka-Client。

        所以,我们得改造配置中心Config-Server项目

        2.1  导入依赖

        为配置中心Config-Server增加Eureka-Client依赖。

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

        2.2  修改application.yml配置文件

        与第六节相比,只是多了第二段的配置,找到配置中心的位置,并把自己注册进去。完整的配置文件如下

#项目部署的端口
server:
  port: 8001


#配置注册中心的位置,并把自己注册进去
eureka:
  client:
    serviceUrl:
      defaultZone: http://localhost:8761/eureka/

spring:
  #当前项目的名字
  application:
    name: spring-cloud-config-server

  #配置中心的相关配置
  cloud:
    config:
      server:
        git:
          # 配置git仓库的URL地址
          uri: https://github.com/hairdryre/Study_SpringCloud   
          # git仓库地址下的文件夹,可以配置多个,用“,”分割。
          search-paths: config/chapter6
          #公共仓库可不用配置帐号密码                         
          username:                                             
          password:                                             

        2.3  在启动类上增加注解

       在启动类上增加@EnableEurekaClient注解

package com.safesoft.server;

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;

/**
 * @author jay.zhou
 * @date 2019/1/27
 * @time 14:09
 */
@SpringBootApplication
@EnableConfigServer
@EnableEurekaClient
public class ApplicationServer {
    public static void main(String[] args) {
        SpringApplication.run(ApplicationServer.class, args);
    }
}

四、改造Client端

         4.1  导入依赖

        配置中心被加入到了注册中心中,同理,那么Client端也要被加入到注册中心中。

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

         4.2  修改bootstrap.properties配置文件

新增下面三段配置

#服务注册地址
eureka.client.serviceUrl.defaultZone=http://localhost:8761/eureka/
#从配置中心读取文件
spring.cloud.config.discovery.enabled=true
#配置中心的serviceId
spring.cloud.config.discovery.serviceId=SPRING-CLOUD-CONFIG-SERVER

        完整的配置文件如下 

#对应{application}部分
spring.cloud.config.name=jay-config
#对应{profile}部分。如果想使用别的配置,修改这里成
#spring.cloud.config.profile=test 或者 spring.cloud.config.profile=pro
spring.cloud.config.profile=pro
#配置中心的具体地址,即Server的端口
spring.cloud.config.uri=http://localhost:8001/
#git分支
spring.cloud.config.label=master
#服务注册地址
eureka.client.serviceUrl.defaultZone=http://localhost:8761/eureka/
#从配置中心读取文件
spring.cloud.config.discovery.enabled=true
#配置中心的serviceId
spring.cloud.config.discovery.serviceId=SPRING-CLOUD-CONFIG-SERVER

        4.3  修改启动类

        在启动类上增加@EnableEurekaClient即可

package com.safesoft.client;

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

/**
 * @author jay.zhou
 * @date 2019/1/27
 * @time 14:18
 */
@SpringBootApplication
@EnableEurekaClient
public class ApplicationClient {
    public static void main(String[] args) {
        SpringApplication.run(ApplicationClient.class, args);
    }
}

        4.4  测试

       我部署了两个配置中心,分别部署在8001端口与8003端口。再部署Client客户端到8002端口。

       依次开启注册中心,配置中心,Client。访问http://localhost:8761/,查看注册中心中的服务器。我本机的效果如图。

        在浏览器上尝试通过部署在8001端口的配置中心,读取GIT上的配置文件。

        访问:http://localhost:8001/jay-config/dev效果如图所示。

        同样,测试部署在8001端口的配置中心,看是否能够读取到配置文件。

        访问:http://localhost:8003/jay-config/dev效果如图所示。

        最后测试:先访问http://localhost:8002/hello,看是否能够获取到GIT上的配置。再随机挂掉一个配置中心,再尝试访问http://localhost:8002/hello,看看还是否能够获取到配置文件信息。

        下面是我完整的测试流程GIF,刚开始有8001配置中心与8003配置中心。在8002端口的Client可以访问到数据。随机挂掉一个配置中心,再尝试在8002端口的Client获取GIt上的配置文件,仍然可以访问到。说明配置中心也可以集群部署。

         点击下面的GIF动图可查看高清图片。

       

五、源码下载

         https://github.com/hairdryre/Study_SpringCloud

         参考文章: 

         史上最简单的SpringCloud教程 | 第七篇: 高可用的分布式配置中心(Spring Cloud Config)(Finchley版本)

         springcloud(八):配置中心服务化和高可用 纯洁的微笑

----------------------------------------------------分割线------------------------------------------------------- 

         下一篇:第八节:消息总线

阅读更多

         目录贴:从头开始学SpringCloud目录贴

 

 

posted @ 2022-07-17 12:14  小大宇  阅读(40)  评论(0)    收藏  举报