Spring Cloud Bus:消息总线

SpringBoot实战电商项目mall(20k+star)地址:github.com/macrozheng/…git

摘要

Spring Cloud Bus 使用轻量级的消息代理来链接微服务架构中的各个服务,能够将其用于广播状态更改(例如配置中心配置更改)或其余管理指令,本文将对其用法进行详细介绍。github

Spring Cloud Bus 简介

咱们一般会使用消息代理来构建一个主题,而后把微服务架构中的全部服务都链接到这个主题上去,当咱们向该主题发送消息时,全部订阅该主题的服务都会收到消息并进行消费。使用 Spring Cloud Bus 能够方便地构建起这套机制,因此 Spring Cloud Bus 又被称为消息总线。Spring Cloud Bus 配合 Spring Cloud Config 使用能够实现配置的动态刷新。目前 Spring Cloud Bus 支持两种消息代理:RabbitMQ 和 Kafka,下面以 RabbitMQ 为例来演示下使用Spring Cloud Bus 动态刷新配置的功能。web

RabbitMQ的安装

  • 安装完成后,进入RabbitMQ安装目录下的sbin目录:

  • 在地址栏输入cmd并回车启动命令行,而后输入如下命令启动管理功能:
rabbitmq-plugins enable rabbitmq_management
复制代码

  • 输入帐号密码并登陆:guest guest

动态刷新配置

使用 Spring Cloud Bus 动态刷新配置须要配合 Spring Cloud Config 一块儿使用,咱们使用上一节中的config-server、config-client模块来演示下该功能。spring

给config-server添加消息总线支持

  • 在pom.xml中添加相关依赖:
<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-bus-amqp</artifactId>
</dependency>
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-actuator</artifactId>
</dependency>
复制代码
  • 添加配置文件application-amqp.yml,主要是添加了RabbitMQ的配置及暴露了刷新配置的Actuator端点;
server:
 port: 8904
spring:
 application:
 name: config-server
 cloud:
 config:
 server:
 git:
 uri: https://gitee.com/macrozheng/springcloud-config.git
 username: macro
 password: 123456
 clone-on-start: true # 开启启动时直接从git获取配置
 rabbitmq: #rabbitmq相关配置
 host: localhost
 port: 5672
 username: guest
 password: guest
eureka:
 client:
 service-url:
 defaultZone: http://localhost:8001/eureka/
management:
 endpoints: #暴露bus刷新配置的端点
 web:
 exposure:
 include: 'bus-refresh'
复制代码

给config-client添加消息总线支持

  • 在pom.xml中添加相关依赖:
<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-bus-amqp</artifactId>
</dependency>
复制代码
  • 添加配置文件bootstrap-amqp1.yml及bootstrap-amqp2.yml用于启动两个不一样的config-client,两个配置文件只有端口号不一样;
server:
 port: 9004
spring:
 application:
 name: config-client
 cloud:
 config:
 profile: dev #启用环境名称
 label: dev #分支名称
 name: config #配置文件名称
 discovery:
 enabled: true
 service-id: config-server
 rabbitmq: #rabbitmq相关配置
 host: localhost
 port: 5672
 username: guest
 password: guest
eureka:
 client:
 service-url:
 defaultZone: http://localhost:8001/eureka/
management:
 endpoints:
 web:
 exposure:
 include: 'refresh'
复制代码

动态刷新配置演示

  • 咱们先启动相关服务,启动eureka-server,以application-amqp.yml为配置启动config-server,以bootstrap-amqp1.yml为配置启动config-client,以bootstrap-amqp2.yml为配置再启动一个config-client,启动后注册中心显示以下:

  • 启动全部服务后,咱们登陆RabbitMQ的控制台能够发现Spring Cloud Bus 建立了一个叫springCloudBus的交换机及三个以 springCloudBus.anonymous开头的队列:

  • 咱们先修改Git仓库中dev分支下的config-dev.yml配置文件:
# 修改前信息
config:
 info: "config info for dev(dev)"
# 修改后信息
config:
 info: "update config info for dev(dev)"  
复制代码

update config info for dev(dev)
复制代码

配合WebHooks使用

WebHooks至关因而一个钩子函数,咱们能够配置当向Git仓库push代码时触发这个钩子函数,这里以Gitee为例来介绍下其使用方式,这里当咱们向配置仓库push代码时就会自动刷新服务配置了。bootstrap

使用到的模块

springcloud-learning
├── eureka-server -- eureka注册中心
├── config-server -- 配置中心服务
└── config-client -- 获取配置的客户端服务
复制代码

项目源码地址

github.com/macrozheng/…bash

公众号

mall项目全套学习教程连载中,关注公众号第一时间获取。架构

公众号图片
相关文章
相关标签/搜索