Spring cloud bus:

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

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

    

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

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

搭建步骤:

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

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

    

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

    

  第三步:修改配置文件:

    

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

    

    

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

  

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


  

最新文章

  1. Mysql命令大全
  2. ASP.NET Core中的依赖注入(1):控制反转(IoC)
  3. Hybrid框架UI重构之路:二、事出有因
  4. Spring学习笔记—最小化Spring XML配置
  5. NOIp 2014 #5 解方程 Label:数论?
  6. require.js 入门学习 (share)
  7. Zabbix配置文件详解之服务端zabbix_server
  8. code manager tools svn服务安装配置
  9. 原生APP与移动Web App的比较
  10. Linked Server for SQL Server 2012(x64) to Oracle Database 12c(x64)
  11. ssh登录nat模式的VMware虚拟机
  12. 我的第一个python web开发框架(14)——后台管理系统登录功能
  13. UCloud数据盘扩容步骤
  14. Mysql加锁过程详解(3)-关于mysql 幻读理解
  15. Luffy之课程详情页
  16. mysql中的data下的数据文件(.FRM、.MYD、.MYI)恢复为数据
  17. 搭建SpringBoot+dubbo+zookeeper+maven框架(二)
  18. PAT 乙级 1020 月饼 (25) C++版
  19. 关于Spring mvc注解中的定时任务的配置
  20. Cocos2d-x开源、跨平台的游戏引擎

热门文章

  1. Tools - Atom编辑器
  2. Linux入门搭建可视化桌面环境小合集virtual box centOS7.10
  3. Java程序员如何运用所掌握的技术构建一个完整的业务架构
  4. 在Android Studio添加本地aar包引用
  5. Python解析HDF文件 分类: Python 2015-06-25 00:16 743人阅读 评论(0) 收藏
  6. Android开发之漫漫长途 XVII——动画
  7. find 命令参数大全
  8. Tomcat启动时项目重复加载的问题
  9. angularjs学习第五天笔记(第二篇:表单验证升级篇)
  10. vb.bet 控件