一、概述

  ConfigClient(微服务)从ConfigServer端获取自己对应的配置文件,但是目前的问题是:当远程git仓库配置文件发生改变时,每次都是需要重启ConfigCient(微服务),如果有上百上千个微服务呢?我想我们不会一个个去重启每个微服务,也就是说如何让ConfigServer端通知到ConfigClient端?即ConfigClient端如何感知到配置发生更新?

  SpringCloud Bus会向外提供一个http接口,即下图中的/bus/refresh。我们将这个接口配置到git的webhook上,当git上的内容发生改变时,就会自动调用/bus/refresh接口。Bus就会通知ConfigServer,configserver会发布更新消息到消息总线的消息队列,其他服务订阅到该消息就会信息刷新,从而实现整个微服务进行自动刷新。

  SpringCloud Bus官网地址:https://www.springcloud.cc/spring-cloud-bus.html

二、实现方式

(1)方式一:某个微服务承担配置刷新的职责

①提交配置出发post请求调用客户端A的/bus/refresh接口

②客户端A收到请求从Server端更新配置并且发送给Spring Cloud Bus消息总线

③Spring Cloud Bus接收消息并通知给其他连线在总线上的客户端,所有总线上的客户端均能接收到消息。

④其他客户端接收到消息,请求Server端获取最新配置

⑤全部客户端均获取到最新的配置

以上存在问题:

  ①打破微服务的单一原则。微服务本身是业务模块,本不应该承担配置刷新的职责

  ②WebHook的配置也随着承担刷新配置的微服务节点发生变化。

(2)方式二:配置中心Server端承担起配置刷新的职责,原理图如下:

①提交配置触发post请求给server端的/bus/refresh接口

②server端接收到请求并发送给SpringCloud Bus总线

③Sping Cloud Bus接收到消息并通知给其他连接的总线的客户端

④其他客户端接收到通知,请求Server端获取最新配置

⑤全部客户端获取到最新的配置

三、实现步骤

  基于方式二的实现,分为Config Server和Config Client配置

0.RabbitMQ的安装

Linux下RabbitMQ的安装及使用

1.ConfigServer服务端配置

1.1添加pom、application.yml配置

 <!--config server-->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-config-server</artifactId>
</dependency>
<!-- springcloud-bus依赖实现配置自动更新,rabbitmq -->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-bus-amqp</artifactId>
</dependency>

pom

server:
port: 3344 spring:
application:
name: microservice-config-server
cloud:
config:
server:
git:
uri: https://github.com/Simple-Coder/microservice-config.git #github上的仓库地址
search-paths: /**
username: ******** #这里配置用户名
password: ******** #这里配置密码
label: master
rabbitmq:
host: 39.98.190.54 #公网地址
port: 5672
username: guest
password: guest #SpringCloud暴露接口,暴露/bus/refresh接口
management:
security:
enabled: false #开启基本的权限,默认为true
security:
basic:
enabled: false

application.yml

1.2 启动类添加@EnableConfigServer

  ConfigServer服务端配置完成!

2.ConfigClient服务端配置

2.1添加pom依赖、bootstrap.yml配置

<!--config-->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-config</artifactId>
</dependency>
<!--amqp-->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-bus-amqp</artifactId>
</dependency>
<!--actuator-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-actuator</artifactId>
</dependency>

pom

spring:
cloud:
config:
name: microservice-config-client #需要从github上读取的资源名称,注意没有yml名称
profile: test #本次访问的配置项
label: master
uri: http://39.98.190.54:3344 #本服务启动后先去找3344服务,通过SpringCloudConfig获取github的服务地址
rabbitmq:
host: 39.98.190.54
port: 5672
username: guest
password: guest security:
basic:
enabled: false

bootstrap.yml

2.2添加注解: @RefreshScope添加在需要刷新的配置文件上

  至此,Config Client端配置完成!

3.WebHook配置

  前边:ConfigServer和ConfigClient配置完成,要实现自动刷新需要调用/bus/refresh接口通过ConfigServer

3.1方式一:手动调用(post请求):http://config3344.com:3344/bus/refresh

3.2方式二:配置git的webhook ,当git端配置发生改变,自动调用/bus-refresh接口

四、测试

(1)启动ConfigServer(含有公网IP的服务器,我这里买的阿里云服务器)

(2)启动ConfigClient:本地代码工程(microservice-config-client3355)

(3)浏览器访问:http://localhost:5002/config

(4)修改配置文件:microservice-config-client.yml

修改完成以后,查看ConfigServer服务端的控制台日志打印如下:

(5)刷新:http://localhost:5002/config

至此,Config配置自动刷新完成!

本项目地址https://github.com/Simple-Coder/microservice-demo-study

参考链接:https://blog.csdn.net/wtdm_160604/article/details/83720391

SpringCloud全家桶学习之消息总线---SpringCloud Bus的更多相关文章

  1. SpringCloud全家桶学习之Feign负载均衡----Feign(四)

    一.Feign概述 (1)Feign是什么? 官网地址:https://projects.spring.io/spring-cloud/spring-cloud.html#spring-cloud-f ...

  2. SpringCloud全家桶学习之概览(一)

    一.概览 根据百度百科的描述,微服务架构是一项在云中部署应用和服务的新技术.而SpringCloud是微服务架构思想的一个具体实现,它为开发人员提供了构建分布式系统中一些常见模式的工具(服务注册与发现 ...

  3. SpringCloud全家桶学习之一阶段总结(一)

    一.概述 前几篇小博客记录了我学习SpringCloud组件的过程,并与工作中所用的Dubbo框架做了一点比较,基本组件:Eureka.Ribbon.Hystrix.Feign.Zuul.Config ...

  4. SpringCloud全家桶学习之分布式配置中心----Config(七)

    一.概述 (1)背景 微服务意味着将单体应用中的业务拆分成一个个子服务,每个服务的粒度相对较小,因此系统中出现大量的服务.由于每个服务都需要配置必要的配置信息才能运行,所以一套集中式的.动态的配置管理 ...

  5. SpringCloud全家桶学习之服务注册与发现及Eureka高可用集群搭建(二)

    一.Eureka服务注册与发现 (1)Eureka是什么? Eureka是NetFlix的一个子模块,也是核心模块之一.Eureka是一个基于REST的服务,用于定位服务,以实现云端中间层服务发现和故 ...

  6. SpringCloud全家桶学习之路由网关----Zuul(六)

    一.Zuul概述 (1)Zuul是什么? Zuul包含了对请求的路由和过滤的两个最主要的功能,其中路由功能负责将外部请求转发到具体的微服务实例上,是实现外部访问统一入口的基础:而过滤功能则负责对请求的 ...

  7. SpringCloud全家桶学习之断路器---Hystrix(五)

    目前我也在摸索着学习Spring Cloud,本节主要摸索的是服务熔断.服务降级.Hystrix服务监控. 一.Hystrix概述 (1)服务雪崩 服务雪崩:多个微服务之间调用的时候,假设微服务A调用 ...

  8. SpringCloud全家桶学习之客户端负载均衡及自定义负载均衡算法----Ribbon(三)

    一.Ribbon是什么? Spring Cloud Ribbon是基于Netflix Ribbon实现的一套客户端  负载均衡的工具(这里区别于nginx的负载均衡).简单来说,Ribbon是Netf ...

  9. 框架用多了真的会死人的,spring-cloud全家桶与mybitais 集成完整示例(附下载)

    ​ 题外话: 看到这一长串包含各种技术名词的标题,一路走来感觉研发深深的被各种框架给绑架了,从我们刚出生最简单的jsp,servlet打天下,到spring mvc的盛行,再到现在spring-boo ...

随机推荐

  1. 使用NSIS制作可执行程序的安装包

    使用NSIS制作可执行程序的安装包: 1,NSIS下载地址:https://pan.baidu.com/s/1GzzQNXgAlJPJWgjBzVwceA 下载完成之后解压缩,打开安装程序,默认安装即 ...

  2. Linux安装MATLAB2016a

    一.准备工具 matlab2016a的镜像文件和破解文件(链接: https://pan.baidu.com/s/1cxtlOM 密码: cj2u) Linux系统,我用的是deepin15.4,和一 ...

  3. IntelliJ IDEA 2017.3尚硅谷-----配置 Maven

  4. 阻塞队列BlockingQueue之ArrayBlockingQueue

    ArrayBlockingQueue  是数组实现的有界阻塞队列,此队列按照先进先出(FIFO)的原则对元素进行排序. 构造方法: public ArrayBlockingQueue(int capa ...

  5. Python的深拷贝、浅拷贝

    浅拷贝 定义:浅拷贝只是对另外一个变量的内存地址的拷贝,这两个变量指向同一个内存地址的变量值. 浅拷贝的特点: 公用一个值: 这两个变量的内存地址一样: 对其中一个变量的值改变,另外一个变量的值也会改 ...

  6. 红帽 Red Hat Linux相关产品iso镜像下载【百度云】【更新7.6】

    不为什么,就为了方便搜索,特把红帽EL 5.EL6.EL7 的各版本整理一下,共享出来.原文链接正式发布 7.6 :RedHat Enterprise Server 7.6 for x86_64:rh ...

  7. 美化传奇NPC对话框添加图片显示实列

    NPC对话框一般都是文字显示,有些GM想突出版本特色,在NPC对话框加些专业图片,彰显独特之处,其实这是很简单的.下面为你讲解美化传奇NPC对话框添加图片显示实列 我们要添加你要放入npc图片的补丁. ...

  8. android WebView缩放时卡顿问题

    问题描述: WebView 在双指缩放页面时会卡顿 解决过程:有试过打开硬件加速android:hardwareAccelerated="true" 还是没用,纠结了一天,最后屏蔽 ...

  9. Jquery获取html参数, jquery.params.js 获取参数

    ================================ ©Copyright 蕃薯耀 2019年12月31日 http://fanshuyao.iteye.com/ /** * 使用:$.q ...

  10. 安装ipython[win/linux]

    首先以win7  64位系统, python2.7.9为例,linux见底部 1.下载材料http://files.cnblogs.com/files/smileyes/ipython-win64.z ...