springcloud 入门 9 (消息总线)

Spring cloud bus:

    Spring cloud bus通过轻量消息代理连接各个分布的节点。这会用在广播状态的变化(例如配置变化)或者其他的消息指令。Spring bus的一个核心思想是通过分布式的启动器对spring boot应用进行扩展,也可以用来建立一个多个应用之间的通信频道。目前唯一实现的方式是用AMQP消息代理作为通道,同样特性的设置(有些取决于通道的设置)在更多通道的文档中。

    Spring cloud bus被国内很多都翻译为消息总线,也挺形象的。大家可以将它理解为管理和传播所有分布式项目中的消息既可,其实本质是利用了MQ的广播机制在分布式的系统中传播消息,目前常用的有Kafka和RabbitMQ。利用bus的机制可以做很多的事情,其中配置中心客户端刷新就是典型的应用场景之一,我们用一张图来描述bus在配置中心使用的机制。

    

根据此图我们可以看出利用Spring Cloud Bus做配置更新的步骤:

1、提交代码触发post给客户端A发送bus/refresh
2、客户端A接收到请求从Server端更新配置并且发送给Spring Cloud Bus
3、Spring Cloud bus接到消息并通知给其它客户端
4、其它客户端接收到通知,请求Server端获取最新配置
5、全部客户端均获取到最新的配置

搭建步骤:

  只需要在client的基本上进行项目改造既可:

  第一步:引入rabbitmq。spring-cloud-starter-bus-amqp

    

  第二步:启动类加注解  @RefreshScope

    

  第三步:修改配置文件:

    

  第四步:启动测试:先启动服务中心。再启动配置中心服务端,最后启动配置文件客户端

    

 

    

 

     这时我们去代码仓库改变配置文件foo的值。如果是传统的做法,需要重启服务,才能达到配置文件的更新。此时,我们只需要发送post请求:http://localhost:9008/actuator/bus-refresh,你会发现config-client会重新读取配置文件

   

  到这,总线基本上是生效了。后期我们会把这个amqp放到配置中心的服务端,因为现在是入门,暂不介绍那么多,脑子里有这个思想就行。


  

posted @ 2018-09-10 13:33  陽66  阅读(201)  评论(0编辑  收藏  举报