SpringCloud教程七:高可用的分布式配置中心(SpringCloud Config)
当服务有很多 都要从服务中心获取配置时 这是可以将服务中心分布式处理 是系统具备在集群下的大数据处理
主要分为几大步骤:
1.入口添加服务器的两大依赖
2.修改urika配置文件pom并添加入口注解
3.修改客户端

上一篇我们讲述了一个服务如何从配置中心读取文件,配置中心如何从远程git读取配置文件,当服务实例很多时,都从配置中心读取文件,这时可以考虑将配置中心做成一个微服务,将其集群化,从而达到高可用,架构图如下:
这里写图片描述

1:新建一个eureka server工程,命名为config-eureka-server,作为配置服务的注册中心。pom文件如下:


4.0.0

<groupId>com.springcloud</groupId>
<artifactId>config-eureka-server</artifactId>
<version>0.0.1-SNAPSHOT</version>
<packaging>jar</packaging>

<name>config-eureka-server</name>
<description>Demo project for Spring Boot</description>

<parent>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-parent</artifactId>
    <version>1.5.9.RELEASE</version>
    <relativePath/> <!-- lookup parent from repository -->
</parent>

<properties>
    <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
    <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
    <java.version>1.8</java.version>
    <spring-cloud.version>Edgware.RELEASE</spring-cloud.version>
</properties>

<dependencies>
    <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-starter-eureka-server</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-test</artifactId>
        <scope>test</scope>
    </dependency>
</dependencies>

<dependencyManagement>
    <dependencies>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-dependencies</artifactId>
            <version>${spring-cloud.version}</version>
            <type>pom</type>
            <scope>import</scope>
        </dependency>
    </dependencies>
</dependencyManagement>

<build>
    <plugins>
        <plugin>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-maven-plugin</artifactId>
        </plugin>
    </plugins>
</build>
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 入口类加入相应注解:

@EnableEurekaServer
@SpringBootApplication
public class ConfigEurekaServerApplication {

public static void main(String[] args) {

    SpringApplication.run(ConfigEurekaServerApplication.class, args);
}

}
1
2
3
4
5
6
7
8
9
10
修改配置文件如下:

server.port=8889
eureka.instance.hostname=localhost

配置成服务

eureka.client.registerWithEureka= false
eureka.client.fetchRegistry=false
eureka.client.service-url.defaultZone= http://${eureka.instance.hostname}😒{server.port}/eureka/
1
2
3
4
5
6
2:修改之前的config-server工程
在pom中加入需要的依赖;

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

1
2
3
4
5
6
7
8
修改配置文件:

spring.application.name=config-server
server.port=8888

配置文件在本地

spring.profiles.active=native

配置文件的目录

spring.cloud.config.server.native.search-locations=D:/workspace/GitHub/spring-config/config-file

spring.cloud.config.server.git.uri=https://github.com/forezp/SpringcloudConfig/

spring.cloud.config.server.git.uri=https://github.com/iot-wangshuyu/springcloud

配置仓库路径

spring.cloud.config.server.git.searchPaths=SpringcloudConfig/respo/

配置仓库的分支

spring.cloud.config.label=master

访问git仓库的用户名

spring.cloud.config.server.git.username=

访问git仓库的用户密码

spring.cloud.config.server.git.password=

注册服务地址

eureka.client.service-url.defaultZone=http://localhost:8889/eureka/
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
修改启动类:

@SpringBootApplication
@EnableConfigServer
@EnableEurekaClient
public class ConfigServerApplication {

public static void main(String[] args) {

    SpringApplication.run(ConfigServerApplication.class, args);
}

}
1
2
3
4
5
6
7
8
9
10
11
3:修改config-client工程

pom中添加相应的依赖:

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

    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-test</artifactId>
        <scope>test</scope>
    </dependency>

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

修改配置文件名称为:bootstrap.properties
内容修改为:

服务名称

spring.application.name=config-client

仓库分支

spring.cloud.config.label=master

dev开发环境配置文件

test测试环境

pro正式环境

spring.cloud.config.profile=dev

使用eureka server的时候需要注释掉

spring.cloud.config.uri= http://localhost:8888/

服务注册地址

eureka.client.service-url.defaultZone=http://localhost:8889/eureka/

从远程获取配置文件

spring.cloud.config.discovery.enabled=true

订阅的服务名称

spring.cloud.config.discovery.service-id=config-server
server.port=8881

如果配置服务部署多份,通过负载均衡,从而高可用。
依次启动程序,config-eureka-server,config-server,config-client,浏览器访问:http://localhost:8889/可以查看服务注册情况;
浏览器访问:http://localhost:8881/hi;返回配置文件中的foo属性;
说明高可用分布式配置中心配置成功