Spring Cloud Hoxton 版本搭建 Bus消息总线(Rabbitmq)

Spring Cloud Hoxton 版本搭建 Bus消息总线(Rabbitmq)


前言

在上一篇文章博主已经讲解了项目如何创建,不会的话可以前往学习,传送门:Spring Cloud Hoxton 版本微服务项目搭建eureka注册中心 。

本篇用来讲解–Spring Cloud Hoxton 版本搭建 Bus消息总线(Rabbitmq)!


摘要

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


Spring Cloud Bus 简介

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


RabbitMQ的安装

安装Erlang,下载地址:http://erlang.org/download…

Spring Cloud Hoxton 版本搭建 Bus消息总线(Rabbitmq)_第1张图片

Spring Cloud Hoxton 版本搭建 Bus消息总线(Rabbitmq)_第2张图片

安装RabbitMQ,下载地址:https://dl.bintray.com/rabbitmq…

Spring Cloud Hoxton 版本搭建 Bus消息总线(Rabbitmq)_第3张图片

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

Spring Cloud Hoxton 版本搭建 Bus消息总线(Rabbitmq)_第4张图片

在RabbitMQ安装目录下的sbin目录的地址栏输入cmd并回车启动命令行,然后输入以下命令启动管理功能:(传送门:rabbitmq启动方式)

rabbitmq-plugins enable rabbitmq_management

Spring Cloud Hoxton 版本搭建 Bus消息总线(Rabbitmq)_第5张图片

访问地址查看是否安装成功:http://localhost:15672/ (默认的端口号)

Spring Cloud Hoxton 版本搭建 Bus消息总线(Rabbitmq)_第6张图片

输入账号密码并登录:guest guest (默认的账户密码)


动态刷新配置

使用 Spring Cloud Bus 动态刷新配置需要配合 Spring Cloud Config 一起使用。


config-center 配置中心添加消息总线支持

在pom.xml中添加相关依赖:



    org.springframework.cloud
    spring-cloud-starter-bus-amqp



    org.springframework.boot
    spring-boot-starter-actuator

添加配置yml,主要用于添加RabbitMQ的配置以及暴露刷新配置的Actuator端点;

spring:
  application:
    #服务名称,随便写
    name: config-center
  config:
    name: config-center
  cloud:
    config:
      server:
        git:
          # 配置存储配置信息的Git仓库
          uri: https://github.com/chenxiban/SpringCloud-Config.git
          # github账户名
          username: chenxiban
          # github密码
          password: w867647213
          # 开启启动时直接从git获取配置
          clone-on-start: true
          # 配置 git 存储器
          default-label: master
          # 指定配置环境所在路径
          # search-paths: /doc/config
          # 获取子目录下的配置
  #          search-paths: '{application}'
  security:
    user:
      # 配置用户名和密码
      name: root
      password: 123456
  # rabbitmq相干配置
  rabbitmq:
    host: localhost
    port: 5672
    username: guest
    password: guest
    
# Admin 管理配置,暴露bus刷新配置的端点
management:
  endpoints:
    web:
      exposure:
        include: 'bus-refresh'
  endpoint:
    health:
      show-details: always

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

在pom.xml中添加相关依赖:



    org.springframework.cloud
    spring-cloud-starter-bus-amqp

这里可以添加两个配置文件bootstrap-amqp1.yml及bootstrap-amqp2.yml用于启动两个不同的config-client,两个配置文件只有端口号不同;

spring:
  application:
    #服务名称,随便写
    name: resource-center
  profiles:
    active: master
  cloud:
    # config客户端配置
    config:
      # 分支名称
      label: master
      # 启用配置后缀名称
      profile: dev
      # 配置文件名称
      name: config
      # 配置中心地址(子项目地址)
      uri: http://localhost:9010
      # 用于向配置中心进行安全认证,需要和配置中心的安全认证账户密码一致
      username: root
      password: 123456
      discovery:
        enabled: true
        service-id: config-center
  # rabbitmq配置
  rabbitmq:
    host: localhost
    port: 5672
    username: guest
    password: guest

# Admin 管理配置
management:
  endpoints:
    web:
      exposure:
        # 开启了 'refresh' 端点
        include: '*'
  endpoint:
    health:
      show-details: always

动态刷新配置演示

按顺序启动项目后,注册中心如下:

Spring Cloud Hoxton 版本搭建 Bus消息总线(Rabbitmq)_第7张图片

启动所有服务后,我们登录RabbitMQ的控制台可以发现 Spring Cloud Bus 创建了一个叫springCloudBus的交换机及三个以 springCloudBus.anonymous开头的队列:

Spring Cloud Hoxton 版本搭建 Bus消息总线(Rabbitmq)_第8张图片

Spring Cloud Hoxton 版本搭建 Bus消息总线(Rabbitmq)_第9张图片
调用 http://localhost:4010/configInfo,结果如下

Spring Cloud Hoxton 版本搭建 Bus消息总线(Rabbitmq)_第10张图片

现在我们修改GitHub仓库中master分支下的config-dev.yml配置文件:

Spring Cloud Hoxton 版本搭建 Bus消息总线(Rabbitmq)_第11张图片

调用注册中心的接口刷新所有配置:http://localhost:9010/actuator/bus-refresh

Spring Cloud Hoxton 版本搭建 Bus消息总线(Rabbitmq)_第12张图片

刷新后再调用 http://localhost:4010/configInfo 获取配置信息


其更多操作自己尝试一下!


最后

  • 更多参考精彩博文请看这里:《陈永佳的博客》

  • 喜欢博主的小伙伴可以加个关注、点个赞哦,持续更新嘿嘿!

你可能感兴趣的:(为霞而作,Spring,Cloud,Hoxton,rabbitmq,spring,boot,git)