SpringCloud全家桶学习之消息总线---SpringCloud Bus
一、概述
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的安装
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的更多相关文章
- SpringCloud全家桶学习之Feign负载均衡----Feign(四)
一.Feign概述 (1)Feign是什么? 官网地址:https://projects.spring.io/spring-cloud/spring-cloud.html#spring-cloud-f ...
- SpringCloud全家桶学习之概览(一)
一.概览 根据百度百科的描述,微服务架构是一项在云中部署应用和服务的新技术.而SpringCloud是微服务架构思想的一个具体实现,它为开发人员提供了构建分布式系统中一些常见模式的工具(服务注册与发现 ...
- SpringCloud全家桶学习之一阶段总结(一)
一.概述 前几篇小博客记录了我学习SpringCloud组件的过程,并与工作中所用的Dubbo框架做了一点比较,基本组件:Eureka.Ribbon.Hystrix.Feign.Zuul.Config ...
- SpringCloud全家桶学习之分布式配置中心----Config(七)
一.概述 (1)背景 微服务意味着将单体应用中的业务拆分成一个个子服务,每个服务的粒度相对较小,因此系统中出现大量的服务.由于每个服务都需要配置必要的配置信息才能运行,所以一套集中式的.动态的配置管理 ...
- SpringCloud全家桶学习之服务注册与发现及Eureka高可用集群搭建(二)
一.Eureka服务注册与发现 (1)Eureka是什么? Eureka是NetFlix的一个子模块,也是核心模块之一.Eureka是一个基于REST的服务,用于定位服务,以实现云端中间层服务发现和故 ...
- SpringCloud全家桶学习之路由网关----Zuul(六)
一.Zuul概述 (1)Zuul是什么? Zuul包含了对请求的路由和过滤的两个最主要的功能,其中路由功能负责将外部请求转发到具体的微服务实例上,是实现外部访问统一入口的基础:而过滤功能则负责对请求的 ...
- SpringCloud全家桶学习之断路器---Hystrix(五)
目前我也在摸索着学习Spring Cloud,本节主要摸索的是服务熔断.服务降级.Hystrix服务监控. 一.Hystrix概述 (1)服务雪崩 服务雪崩:多个微服务之间调用的时候,假设微服务A调用 ...
- SpringCloud全家桶学习之客户端负载均衡及自定义负载均衡算法----Ribbon(三)
一.Ribbon是什么? Spring Cloud Ribbon是基于Netflix Ribbon实现的一套客户端 负载均衡的工具(这里区别于nginx的负载均衡).简单来说,Ribbon是Netf ...
- 框架用多了真的会死人的,spring-cloud全家桶与mybitais 集成完整示例(附下载)
题外话: 看到这一长串包含各种技术名词的标题,一路走来感觉研发深深的被各种框架给绑架了,从我们刚出生最简单的jsp,servlet打天下,到spring mvc的盛行,再到现在spring-boo ...
随机推荐
- 使用NSIS制作可执行程序的安装包
使用NSIS制作可执行程序的安装包: 1,NSIS下载地址:https://pan.baidu.com/s/1GzzQNXgAlJPJWgjBzVwceA 下载完成之后解压缩,打开安装程序,默认安装即 ...
- Linux安装MATLAB2016a
一.准备工具 matlab2016a的镜像文件和破解文件(链接: https://pan.baidu.com/s/1cxtlOM 密码: cj2u) Linux系统,我用的是deepin15.4,和一 ...
- IntelliJ IDEA 2017.3尚硅谷-----配置 Maven
- 阻塞队列BlockingQueue之ArrayBlockingQueue
ArrayBlockingQueue 是数组实现的有界阻塞队列,此队列按照先进先出(FIFO)的原则对元素进行排序. 构造方法: public ArrayBlockingQueue(int capa ...
- Python的深拷贝、浅拷贝
浅拷贝 定义:浅拷贝只是对另外一个变量的内存地址的拷贝,这两个变量指向同一个内存地址的变量值. 浅拷贝的特点: 公用一个值: 这两个变量的内存地址一样: 对其中一个变量的值改变,另外一个变量的值也会改 ...
- 红帽 Red Hat Linux相关产品iso镜像下载【百度云】【更新7.6】
不为什么,就为了方便搜索,特把红帽EL 5.EL6.EL7 的各版本整理一下,共享出来.原文链接正式发布 7.6 :RedHat Enterprise Server 7.6 for x86_64:rh ...
- 美化传奇NPC对话框添加图片显示实列
NPC对话框一般都是文字显示,有些GM想突出版本特色,在NPC对话框加些专业图片,彰显独特之处,其实这是很简单的.下面为你讲解美化传奇NPC对话框添加图片显示实列 我们要添加你要放入npc图片的补丁. ...
- android WebView缩放时卡顿问题
问题描述: WebView 在双指缩放页面时会卡顿 解决过程:有试过打开硬件加速android:hardwareAccelerated="true" 还是没用,纠结了一天,最后屏蔽 ...
- Jquery获取html参数, jquery.params.js 获取参数
================================ ©Copyright 蕃薯耀 2019年12月31日 http://fanshuyao.iteye.com/ /** * 使用:$.q ...
- 安装ipython[win/linux]
首先以win7 64位系统, python2.7.9为例,linux见底部 1.下载材料http://files.cnblogs.com/files/smileyes/ipython-win64.z ...