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 ...
随机推荐
- Python记:列表方法略记
- Java连载77-Integer常用方法、Integer、int、String三者相互转化、自动装箱、自动拆箱
一.关于Integer中常用的方法 package com.bjpowernode.java_learning; public class D77_1_ { public static void ...
- SpringCloud Netflix Hystrix
Hystrix的一些概念 Hystrix是一个容错框架,可以有效停止服务依赖出故障造成的级联故障. 和eureka.ribbon.feign一样,也是Netflix家的开源框架,已被SpringClo ...
- js -- 车牌号对应的归属地js文件
/*车牌号对应的归属地*/ let cardCallerloc = new Map(); // 北京市(京) cardCallerloc.set("京A", "北京市&q ...
- iterations 快捷键
原帖:https://blog.csdn.net/Soinice/article/details/83505198 为了防止删除备份的. iterations 快捷键 Live Templates 其 ...
- keil密钥过期 新注册机 有效期至2032年
点击下载:keil注册机至2032年
- SpringMVC项目使用elastic search搜索
项目需要,引入了elastic search(后续简称es),后面将介绍本地对es的安装,使用以及java连接es查询的整个过程. 1.es索引字段建立与修改,以curl新增一个索引字段示例 curl ...
- linux零碎001
glibc:GNU发布的libc库,即c运行库.glibc是linux系统中最底层的api,几乎其它任何运行库都会依赖于glibc. uclibc:是一个面向嵌入式Linux系统的小型的C标准库.最初 ...
- sqlserver数据库导入大批量数据
参考: https://www.cnblogs.com/zhangliangzlee/p/3585862.html
- 求int型正整数在内存中存储时1的个数 && int型的数到底最大是多少?
输入一个int型的正整数(十位数之内!嘞!),计算出该int型数据在内存中存储时1的个数. #include<bits/stdc++.h> using namespace std; int ...