SpringCloud H版系列10--Bus消息中心

Bus消息中心

书接上文,继续跟着周阳老师学习SpringCloud的消息中心Bus。

一、Spring Cloud Bus

Spring Cloud Bus 集成了市面上常用的消息代理(rabbitmq、kafka等 2种),连接微服务系统中的所有节点,当有数据变更时,可以通过消息代理广播通知微服务及时变更数据;例如微服务的配置更新。

1.1Bus 解决的问题

Bus 解决了微服务数据变更,及时同步的问题。
Spring cloud bus目前只这次RabbitMQ/Kafka作为消息总线,并没有对ActiveMQ/RokcetMQ做支持。

1.2刷新类型介绍

Bus消息总线的刷新类型有两类,一类是对client整合,通过client接口刷新一个client后,经过bus通知其他的client刷新信息。如下图:
SpringCloud H版系列10--Bus消息中心
Bus消息总线刷新类型第二种是通知统一配置管理中心,将由统一配置管理中心通知bus,然后告诉其他的微服务获取配置信息。如下图:
SpringCloud H版系列10--Bus消息中心

1.3 Bus消息中心原理和思想

设计原理:
ConfigBus实例监听MQ中同一个topic(默认是springCloudBus).当一个服务刷新数据的时候,它会把这个消息放入到Topic中,这样其他监听同一个Topic的服务就能得到通知,然后去更新自身的配置;

设计思想:
1)利用消息总线触发一个客户端/bus/refresh,而刷新所有客户端的配置:破环微服务单一性,对等性;
2)利用消息总线触发一个服务端ConfigServer的/bus/fresh端点,而刷新所有客户端的配置;

二、搭建RabbitMQ

搭建过程请自行谷歌、百度
双击RabbitMQ service start
浏览器输入:localhost:15672 ,输入账号和密码:guest、guest 可以看到RabbitMQ的主界面
SpringCloud H版系列10--Bus消息中心

三、参照3355模块新建3366模块

bootstrap.yml

server:
  port: 3366

spring:
  application:
    name: config-client
  cloud:
    config:
      label: master
      name: config
      profile: dev
      uri: http://localhost:3344
  #15672是管理界面端口,5672是MQ访问的端口
  rabbitmq:
    host: localhost
    port: 5672
    username: guest
    password: guest
eureka:
  client:
    service-url:
      defaultZone: http://localhost:7001/eureka
# 暴露监控端点
management:
  endpoints:
    web:
      exposure:
        include: "*"

ConfigClientMain3366

@SpringBootApplication
@EnableEurekaClient
public class ConfigClientMain3366 {
    /*消息总线:
    微服务中使用轻量级消息代理来构建一个共用的消息主题,并让微服务系统中所有实例都连接上来。
    *由于该主题中产生的消息会被所有实例监听和消费,所以称为消息总线。
    *在总线上个各个实例,都可以广播一些需要其他连接到该主题上的实例都知道的消息
    *
    * 基本原理:
    * ConfigClient实例都监听MQ中同一个topic(默认是SpringCloudBus),当一个服务刷新数据时,会把这个信息放到topic
    * ,这样其他监听到同一个topic服务就能得到通知,然后去更新自身的配置。
    */

    //利用消息总线,触发一个服务器端ConfigServer的bus/refresh端点,而刷新所有客户端的配置,总的来说就是:实现自动刷新配置功能
    //用3344作为Server,通知3355、3366两个Client
    public static void main(String[] args) {
        SpringApplication.run(ConfigClientMain3366.class, args);
    }
}

ConfigClientController

@RestController
@RefreshScope
public class ConfigClientController {

    @Value("${server.port}")
    private String serverPort;

    @Value("${config.info}")
    private String configInfo;

    @GetMapping("/configInfo")
    public String configInfo(){
        return "serverPort: " +serverPort+ "\t\n\n configInfo: "+ configInfo;
    }
}

3355、3366yml新增:

rabbitmq: #rabbitmq相关配置,15672是web管理端口,5672是mq访问端口
  port: 5672
  host: localhost
  username: guest
  password: guest
 
#暴露监控端点
management:
  endpoints:
    web:
      exposure:
        include: "*"

四、测试

1、修改Gitee中config-dev.yml版本号
2、cmd 刷新3344
cmd窗口中执行

curl -X POST "http://localhost:3344/actuator/bus-refresh"

结果:3355、3366 都已经改变,一次修改、广播通知、到处运行。
上面是全局通知,但如果我们想定点通知该如何做呢?
定点通知:只通知3355,不通知3366
实现方法:cmd 刷新3344

curl -X POST "http://localhost:3344/actuator/bus-refresh/config-client:3355"
上一篇:记录一次pl2303串口驱动解决故障


下一篇:(25)UVM 寄存器模型集成