博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
springcloud(八):配置中心服务化和高可用
阅读量:5097 次
发布时间:2019-06-13

本文共 3974 字,大约阅读时间需要 13 分钟。

在前两篇的介绍中,客户端都是直接调用配置中心的server端来获取配置文件信息。这样就存在了一个问题,客户端和服务端的耦合性太高,如果server端要做集群,客户端只能通过原始的方式来路由,server端改变IP地址的时候,客户端也需要修改配置,不符合springcloud服务治理的理念。springcloud提供了这样的解决方案,我们只需要将server端当做一个服务注册到eureka中,client端去eureka中去获取配置中心server端的服务既可。

这篇文章我们基于配置中心git版本的内容来改造

server端改造

1、添加依赖

org.springframework.cloud
spring-cloud-config-server
org.springframework.cloud
spring-cloud-starter-eureka

需要多引入spring-cloud-starter-eureka包,来添加对eureka的支持。

2、配置文件

server:server:  port: 8001spring:  application:    name: spring-cloud-config-server  cloud:    config:      server:        git:          uri: https://github.com/ityouknow/spring-cloud-starter/     # 配置git仓库的地址          search-paths: config-repo                             # git仓库地址下的相对地址,可以配置多个,用,分割。          username: username                                        # git仓库的账号          password: password                                    # git仓库的密码eureka:  client:    serviceUrl:      defaultZone: http://localhost:8000/eureka/   ## 注册中心eurka地址

增加了eureka注册中心的配置

3、启动类

启动类添加@EnableDiscoveryClient激活对配置中心的支持

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

这样server端的改造就完成了。先启动eureka注册中心,在启动server端,在浏览器中访问:http://localhost:8000/ 就会看到server端已经注册了到注册中心了。

按照上篇的测试步骤对server端进行测试服务正常。

客户端改造

1、添加依赖

org.springframework.cloud
spring-cloud-starter-config
org.springframework.boot
spring-boot-starter-web
org.springframework.cloud
spring-cloud-starter-eureka
org.springframework.boot
spring-boot-starter-test
test

需要多引入spring-cloud-starter-eureka包,来添加对eureka的支持。

2、配置文件

spring.application.name=spring-cloud-config-clientserver.port=8002spring.cloud.config.name=neo-configspring.cloud.config.profile=devspring.cloud.config.label=masterspring.cloud.config.discovery.enabled=truespring.cloud.config.discovery.serviceId=spring-cloud-config-servereureka.client.serviceUrl.defaultZone=http://localhost:8000/eureka/

主要是去掉了spring.cloud.config.uri直接指向server端地址的配置,增加了最后的三个配置:

  • spring.cloud.config.discovery.enabled :开启Config服务发现支持
  • spring.cloud.config.discovery.serviceId :指定server端的name,也就是server端spring.application.name的值
  • eureka.client.serviceUrl.defaultZone :指向配置中心的地址

这三个配置文件都需要放到bootstrap.properties的配置中

3、启动类

启动类添加@EnableDiscoveryClient激活对配置中心的支持

@EnableDiscoveryClient@SpringBootApplicationpublic class ConfigClientApplication {    public static void main(String[] args) {        SpringApplication.run(ConfigClientApplication.class, args);    }}

启动client端,在浏览器中访问:http://localhost:8000/ 就会看到server端和client端都已经注册了到注册中心了。

高可用

为了模拟生产集群环境,我们改动server端的端口为8003,再启动一个server端来做服务的负载,提供高可用的server端支持。

如上图就可发现会有两个server端同时提供配置中心的服务,防止某一台down掉之后影响整个系统的使用。

我们先单独测试服务端,分别访问:http://localhost:8001/neo-config/devhttp://localhost:8003/neo-config/dev返回信息:

{    "name": "neo-config",     "profiles": [        "dev"    ],     "label": null,     "version": null,     "state": null,     "propertySources": [        {            "name": "https://github.com/ityouknow/spring-cloud-starter/config-repo/neo-config-dev.properties",             "source": {                "neo.hello": "hello im dev"            }        }    ]}

说明两个server端都正常读取到了配置信息。

再次访问:http://localhost:8002/hello,返回:hello im dev update。说明客户端已经读取到了server端的内容,我们随机停掉一台server端的服务,再次访问http://localhost:8002/hello,返回:hello im dev update,说明达到了高可用的目的。

转载于:https://www.cnblogs.com/jianliang-Wu/p/8945807.html

你可能感兴趣的文章
密码技术发展几十年 我们真的安全了吗?
查看>>
workerman需要的php模块posix、pcntl、sysvshm、sysvmsg缺少,怎么办
查看>>
AtCoder Beginner Contest 075 D - Axis-Parallel Rectangle
查看>>
arc 093 D – Grid Components
查看>>
关于C++ STL标准库中map 的多元素应用
查看>>
MSDN资源免费下载 之备份网站
查看>>
Pentium
查看>>
[编织消息框架][netty源码分析]11 ByteBuf 实现类UnpooledHeapByteBuf职责与实现
查看>>
2.理解ASP.NET MVC的执行过程
查看>>
poj - 2186 Popular Cows && poj - 2553 The Bottom of a Graph (强连通)
查看>>
搜狗面经汇总
查看>>
如何在个人博客中插入Jsbin或者jsfiddle代码
查看>>
js实现无缝滚动
查看>>
最新32位和64位xp,win7,win8,win10系统大全(电脑装机版)
查看>>
如何向非技术人(程序猿)解释SQL注入?
查看>>
Convolutional_LSTM论文
查看>>
struts2笔记
查看>>
【NOIP模拟赛】就 反悔贪心
查看>>
vue的插槽slot
查看>>
ernd
查看>>