SpringCloud教程七:高可用的分布式配置中心(SpringCloud Config)

雨点打透心脏的1/2处 2021-09-14 10:58 433阅读 0赞

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

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

  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
  3. <modelVersion>4.0.0</modelVersion>
  4. <groupId>com.springcloud</groupId>
  5. <artifactId>config-eureka-server</artifactId>
  6. <version>0.0.1-SNAPSHOT</version>
  7. <packaging>jar</packaging>
  8. <name>config-eureka-server</name>
  9. <description>Demo project for Spring Boot</description>
  10. <parent>
  11. <groupId>org.springframework.boot</groupId>
  12. <artifactId>spring-boot-starter-parent</artifactId>
  13. <version>1.5.9.RELEASE</version>
  14. <relativePath/> <!-- lookup parent from repository -->
  15. </parent>
  16. <properties>
  17. <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
  18. <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
  19. <java.version>1.8</java.version>
  20. <spring-cloud.version>Edgware.RELEASE</spring-cloud.version>
  21. </properties>
  22. <dependencies>
  23. <dependency>
  24. <groupId>org.springframework.cloud</groupId>
  25. <artifactId>spring-cloud-starter-eureka-server</artifactId>
  26. </dependency>
  27. <dependency>
  28. <groupId>org.springframework.boot</groupId>
  29. <artifactId>spring-boot-starter-web</artifactId>
  30. </dependency>
  31. <dependency>
  32. <groupId>org.springframework.boot</groupId>
  33. <artifactId>spring-boot-starter-test</artifactId>
  34. <scope>test</scope>
  35. </dependency>
  36. </dependencies>
  37. <dependencyManagement>
  38. <dependencies>
  39. <dependency>
  40. <groupId>org.springframework.cloud</groupId>
  41. <artifactId>spring-cloud-dependencies</artifactId>
  42. <version>${spring-cloud.version}</version>
  43. <type>pom</type>
  44. <scope>import</scope>
  45. </dependency>
  46. </dependencies>
  47. </dependencyManagement>
  48. <build>
  49. <plugins>
  50. <plugin>
  51. <groupId>org.springframework.boot</groupId>
  52. <artifactId>spring-boot-maven-plugin</artifactId>
  53. </plugin>
  54. </plugins>
  55. </build>
  56. </project>

入口类加入相应注解:

  1. @EnableEurekaServer
  2. @SpringBootApplication
  3. public class ConfigEurekaServerApplication {
  4. public static void main(String[] args) {
  5. SpringApplication.run(ConfigEurekaServerApplication.class, args);
  6. }
  7. }

修改配置文件如下:

  1. server.port=8889
  2. eureka.instance.hostname=localhost
  3. #配置成服务
  4. eureka.client.registerWithEureka= false
  5. eureka.client.fetchRegistry=false
  6. eureka.client.service-url.defaultZone= http://${eureka.instance.hostname}:${server.port}/eureka/

2:修改之前的config-server工程
在pom中加入需要的依赖;

  1. <dependency>
  2. <groupId>org.springframework.cloud</groupId>
  3. <artifactId>spring-cloud-starter-eureka</artifactId>
  4. </dependency>
  5. <dependency>
  6. <groupId>org.springframework.cloud</groupId>
  7. <artifactId>spring-cloud-config-server</artifactId>
  8. </dependency>

修改配置文件:

  1. spring.application.name=config-server
  2. server.port=8888
  3. #配置文件在本地
  4. #spring.profiles.active=native
  5. #配置文件的目录
  6. #spring.cloud.config.server.native.search-locations=D:/workspace/GitHub/spring-config/config-file
  7. #spring.cloud.config.server.git.uri=https://github.com/forezp/SpringcloudConfig/
  8. spring.cloud.config.server.git.uri=https://github.com/iot-wangshuyu/springcloud
  9. #配置仓库路径
  10. spring.cloud.config.server.git.searchPaths=SpringcloudConfig/respo/
  11. #配置仓库的分支
  12. spring.cloud.config.label=master
  13. #访问git仓库的用户名
  14. spring.cloud.config.server.git.username=
  15. #访问git仓库的用户密码
  16. spring.cloud.config.server.git.password=
  17. #注册服务地址
  18. eureka.client.service-url.defaultZone=http://localhost:8889/eureka/

修改启动类:

  1. @SpringBootApplication
  2. @EnableConfigServer
  3. @EnableEurekaClient
  4. public class ConfigServerApplication {
  5. public static void main(String[] args) {
  6. SpringApplication.run(ConfigServerApplication.class, args);
  7. }
  8. }

3:修改config-client工程

pom中添加相应的依赖:

  1. <dependency>
  2. <groupId>org.springframework.cloud</groupId>
  3. <artifactId>spring-cloud-starter-config</artifactId>
  4. </dependency>
  5. <dependency>
  6. <groupId>org.springframework.boot</groupId>
  7. <artifactId>spring-boot-starter-web</artifactId>
  8. </dependency>
  9. <dependency>
  10. <groupId>org.springframework.boot</groupId>
  11. <artifactId>spring-boot-starter-test</artifactId>
  12. <scope>test</scope>
  13. </dependency>
  14. <dependency>
  15. <groupId>org.springframework.cloud</groupId>
  16. <artifactId>spring-cloud-starter-eureka</artifactId>
  17. </dependency>

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

  1. #服务名称
  2. spring.application.name=config-client
  3. #仓库分支
  4. spring.cloud.config.label=master
  5. #dev开发环境配置文件
  6. #test测试环境
  7. #pro正式环境
  8. spring.cloud.config.profile=dev
  9. #使用eureka server的时候需要注释掉
  10. #spring.cloud.config.uri= http://localhost:8888/
  11. #服务注册地址
  12. eureka.client.service-url.defaultZone=http://localhost:8889/eureka/
  13. #从远程获取配置文件
  14. spring.cloud.config.discovery.enabled=true
  15. #订阅的服务名称
  16. spring.cloud.config.discovery.service-id=config-server
  17. server.port=8881

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

发表评论

表情:
评论列表 (有 0 条评论,433人围观)

还没有评论,来说两句吧...

相关阅读