Spring Cloud Eureka--BUS组件刷新配置

BUS 配置刷新

  • 消息总线,实现动态配置刷新,通过配置中心向MQ服务发送一个刷新指令,其他配置中心客户端接收刷新指令,执行配置刷新

1.添加依赖(2349)

bus rabbitmq binder-rabbit

 <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-amqp</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-bus</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-stream-binder-rabbit</artifactId>
        </dependency>

2.修改09的添加依赖

actuator

		<dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-actuator</artifactId>
        </dependency>

3.修改09yml配置

暴露bus-refresh刷新路径
rabbitmq连接配置

spring:
  application:
    name: config-server
  cloud:
    config:
      server:
        git:
          uri: https://gitee.com/pigeon01/springcloud1
          search-paths: config
  rabbitmq:
    host: 192.168.64.140
    port: 5672
    username: admin
    password: admin
    virtual-host: /    
server:
  port: 6001
eureka:
  client:
    service-url:
      defaultZone: http://eureka1:2001/eureka,http://eureka2:2002/eureka
management:
  endpoints:
    web:
      exposure:
        include: bus-refresh

4.修改234的yml配置

  • 添加rabbitmq连接
  • 修改config的配置
  • 提交推送到远程仓库
spring:
  application:
    name: item-service
  rabbitmq:
    host: 192.168.64.140
    port: 5672
    username: admin
    password: admin
    virtual-host: /
#item 8001 user8101 order8201
server:
  port: 8001
  cloud:
    config:
      override-none: true  #防止从配置中心下载的配置,覆盖本地命令参数
eureka:
  client:
    service-url:
      # 可以从云服务商购买不同地点的 eureka服务器
      # 这里可以改成云服务商提供的地点
      # 自己的服务器只能用defaultZone
      defaultZone: http://eureka1:2001/eureka,http://eureka2:2002/eureka

在这里插入图片描述
在这里插入图片描述

消息服务案例

1. BUS配置刷新测试

1.向http://localhost:6001/actuator/bus-refresh提交一个post请求
2.观察2.3.4控制台是否重新连接6001,刷新配置
在这里插入图片描述
在这里插入图片描述

刷新指令如何只发送到03模块??

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
有选择地可以发送至想发送的模块,使用的是主题交换机

在这里插入图片描述

2.测试03的配置添加新用户,让03刷新配置

1.修改userServiceImpl 添加@RefreshScope

  • 如果不添加这个注 解,即使刷新到新的配置,也不会向对象重新注入新配置
    在这里插入图片描述

2.重启03

在这里插入图片描述

3.修改config目录的user-service-dev.yml

添加99用户
在这里插入图片描述

4.提交到远程仓库

在这里插入图片描述

5.让03刷新配置

POST http://localhost:6001/actuator/bus-refresh/user-service

6.访问新的用户数据

GET http://localhost:3002/user-service/99
在这里插入图片描述

选择正确网卡,注册ip不注册主机名

选择正确网卡

bootstrap.yml

ignore-interfaces:   #忽略的网卡



在这里插入图片描述

spring:
  cloud:
    inetutils:
      preferred-networks:
        - 172\.18\.10\..+

注册ip,不注册主机名

application.yml
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

spring:
  application:
    name: config-server
  cloud:
    config:
      server:
        git:
          uri: https://gitee.com/pigeon01/springcloud1
          search-paths: config
  rabbitmq:
    host: 192.168.64.140
    port: 5672
    username: admin
    password: admin
    virtual-host: /
server:
  port: 6001
eureka:
  client:
    service-url:
      defaultZone: http://eureka1:2001/eureka,http://eureka2:2002/eureka
  instance:
    prefer-ip-address: true
    instance-id: ${spring.cloud.client.ip-address}:${spring.application.name}:${server.port}
management:
  endpoints:
    web:
      exposure:
        include: bus-refresh

实现效果
在这里插入图片描述

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值