欢迎来到菜鸟SpringCloud实战入门系列(SpringCloudForNoob),该系列通过层层递进的实战视角,来一步步学习和理解SpringCloud。
本系列适合有一定Java以及SpringBoot基础的同学阅读。
每篇文章末尾都附有本文对应的Github源代码,方便同学调试。
Github仓库地址:
github.com/qqxx6661/sp…
前文提到,如果需要客户端获取到最新的配置信息需要执行refresh,我们可以利用webhook的机制每次提交代码发送请求来刷新客户端,当客户端越来越多的时候,需要每个客户端都执行一遍,这种方案就不太适合了。使用Spring Cloud Bus可以完美解决这一问题。
Spring bus的一个核心思想是通过分布式的启动器对spring boot应用进行扩展,也可以用来建立一个多个应用之间的通信频道。目前唯一实现的方式是用AMQP消息代理作为通道,同样特性的设置(有些取决于通道的设置)在更多通道的文档中。其实本质是利用了MQ的广播机制在分布式的系统中传播消息,目前常用的有Kafka和RabbitMQ。
以下是本文即将实现的架构:
更新客户端配置文件整个流程是:
请参考我的文章:
blog.csdn.net/qqxx6661/ar…
config-server模块在上一章有介绍
添加依赖:
<dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-bus-kafka</artifactId> </dependency> 复制代码
修改配置文件,添加kafka配置:
springboot2中只需要这一句,不足要zk-node等设置啦。
# kafka stream: kafka: binder: brokers: localhost:9092 bus: trace: enabled: true 复制代码
完整配置文件如下:
server: port: 8769 spring: application: name: spring-cloud-config-server cloud: config: server: git: uri: https://xxxxxxxxxxxx.git # 配置git仓库的地址 search-paths: config-repo # git仓库地址下的相对地址,可以配置多个,用,分割。 username: xxxxxxxx # git仓库的账号 password: xxxxxxx # git仓库的密码 # kafka stream: kafka: binder: brokers: localhost:9092 bus: trace: enabled: true # 客户端调用需要 management: endpoints: web: exposure: include: "*" # 在服务中心注册 eureka: client: serviceUrl: defaultZone: http://localhost:8761/eureka/ 复制代码
服务端设置好了总线,客户端当然也要和总线连接
依赖和配置文件的修改,与config-server一模一样,照着上面修改就可以了。
分别运行eureka,config-server和config-client模块,这里我们开启两个config-client模块,分别对应端口8771,8772.
启动后的进程结构如下:
可以看到eureka里注册了服务端和两个客户端:
我们直接访问config-server,查看服务端现在的配置文件:
http://localhost:8769/spring-cloud-config-dev.properties
查看config-client的hello接口,得到配置文件内容:
http://localhost:8771/hello
接下来,将配置文件修改一下,加点字符。
随后push到远程服务器。
然后访问 http://localhost:8769/spring-cloud-config-dev.properties :
发现已经服务端更新了。
这时候,我们需要做更新, 发送POST请求:
curl -X POST http://localhost:8769/actuator/bus-refresh 复制代码
这是springboot2的请求,和老的请求格式不同,可以从进程启动时候的mapping日志中看出。
这时候请求 :
http://localhost:8771/hello
http://localhost:8772/hello
更新成功!
你还可以通过trace来跟踪总线事件:
一些场景下,我们可能希望知道Spring Cloud Bus事件传播的细节。此时,我们可以跟踪总线事件(RemoteApplicationEvent的子类都是总线事件)。
http://localhost:8769/actuator/httptrace 复制代码
github.com/qqxx6661/sp…
www.ityouknow.com/springcloud…
blog.csdn.net/superdangbo…
mp.weixin.qq.com/s/aZvrYpsWi…