springCould中的Bus-从小白开始【11】

springCould中的Bus-从小白开始【11】_第1张图片

目录

1.Bus是什么❤️❤️❤️

2.什么是总线❤️❤️❤️

3.rabbitmq❤️❤️❤️

4.新建模块3366❤️❤️❤️

5.设计思想 ❤️❤️❤️

6.添加消息总线的支持❤️❤️❤️

7.定点通知❤️❤️❤️


1.Bus是什么❤️❤️❤️

  • SpringCloud Bus是将分布式系统的节点轻量级消息系统链接起来的框架
  • 整合了Java的事件处理机制和消息中间件的功能
  • 目前支持RabbitMQKafka。
  • Spring Cloud Bus配合Spring Cloud Config使用可以实现配置的动态刷新。

2.什么是总线❤️❤️❤️

在微服务架构的系统中,通常会使用轻量级的消息代理来构建一个共用的消息主题,并让系统中所有微服务实例都连接上来。由于该主题中产生的消息会被所有实例监听消费,所以称它为消息总线。在总线上的各个实例,都可以方便地广播一些需要让其他连接在该主题上的实例都知道的消息。

3.rabbitmq❤️❤️❤️

虚拟机上安装好rabbitmq

安装详细请看小张的—>从入门到精通RabbitMQ

4.新建模块3366❤️❤️❤️

4.1.建模块❤️❤️

  • 1.在父工程下创建模块
  • 2.注意jdk和maven版本号

4.2.加pom❤️❤️

    
        
            org.springframework.boot
            spring-boot-starter-web
        
        
            org.springframework.boot
            spring-boot-starter-actuator
        
        
            org.projectlombok
            lombok
            true
        
        
            org.springframework.boot
            spring-boot-starter-test
            test
        
        
            org.example
            cloud-api-commons
            ${project.version}
        
        
        
            org.springframework.cloud
            spring-cloud-starter-netflix-eureka-client
        
        
        
            org.springframework.cloud
            spring-cloud-starter-config
        
    

4.3.改yml❤️❤️

server:
  port: 3366
spring:
  application:
    name: config-client
  cloud:
    config:
      label: master
      profile: dev
      name: config
      uri: http://localhost:3344

eureka:
  client:
    service-url:
      defaultZone:  http://eureka7001.com:7001/eureka,http://eureka7002.com:7002/eureka,http://eureka7003.com:7003/eureka

#暴露监控端点
management:
  endpoints:
    web:
      exposure:
        include: "*"

4.4.主启动类❤️❤️

@SpringBootApplication
@EnableEurekaClient
public class ConfigClientMain3366 {
    public static void main(String[] args) {
        SpringApplication.run(ConfigClientMain3366.class);
    }
}

4.5.业务类❤️❤️

@RestController
@RefreshScope
public class ConfigClientController {
    @Value("${server.port}")
    private String serverPort;

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

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

5.设计思想 ❤️❤️❤️

利用消息总线触发一个服务端ConfigServer的/bus/refresh端点,而刷新所有客户端的配置

springCould中的Bus-从小白开始【11】_第2张图片

6.添加消息总线的支持❤️❤️❤️

6.1.修改3344模块❤️❤️

1.改pom❤️❤️

添加消息总线依赖

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

2.改yml❤️❤️

添加rabbitmq配置,并暴露刷新端点

server:
  port: 3344

spring:
  application:
    name:  cloud-config-center
  cloud:
    config:
      server:
        git:
          #gitee上面的仓库地址
          uri: [email protected]:hqdmdxz/springcould-config.git
          #搜索目录
          search-paths:
            - sprongcloud-config
          #gitee的账号
          username: 18337062987
          #gitee的密码
          password: love4.29
      #读取分支
      lable: master
  #rabbitmq配置
  rabbitmq:
    host: 192.168.20.129
    port: 5672
    username: root
    password: 123456

#注册到eureka
eureka:
  client:
    service-url:
      defaultZone: http://eureka7001.com:7001/eureka,http://eureka7002.com:7002/eureka,http://eureka7003.com:7003/eureka

#暴露bus刷新配置的端点
management:
  endpoints:
    web:
      exposure:
        include: 'bus-refresh'

6.2.修改3355模块❤️❤️

1.改pom❤️❤️

 添加消息总线依赖

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

2.改yml❤️❤️

server:
  port: 3355
spring:
  application:
    name: config-client
  cloud:
    #客户端配置
    config:
      #分支名称
      label: master
      #配置文件名称
      name: config
      #读取后缀名称
      profile: dev
      #配置中心地址
      uri: http://localhost:3344
  rabbitmq:
    host: 192.168.20.129
    port: 5672
    username: root
    password: 123456
#服务注册到eureka
eureka:
  client:
    service-url:
      defaultZone: http://eureka7001.com:7001/eureka,http://eureka7002.com:7002/eureka,http://eureka7003.com:7003/eureka


#暴露监控端点
management:
  endpoints:
    web:
      exposure:
        include: "*"

6.3.修改3366模块❤️❤️

1.改pom❤️❤️

 添加消息总线依赖

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

2.改yml❤️❤️

server:
  port: 3366
spring:
  application:
    name: config-client
  cloud:
    #客户端配置
    config:
      #分支名称
      label: master
      #配置文件名称
      name: config
      #读取后缀名称
      profile: dev
      #配置中心地址
      uri: http://localhost:3344
  rabbitmq:
    host: 192.168.20.129
    port: 5672
    username: root
    password: 123456
#服务注册到eureka
eureka:
  client:
    service-url:
      defaultZone: http://eureka7001.com:7001/eureka,http://eureka7002.com:7002/eureka,http://eureka7003.com:7003/eureka


#暴露监控端点
management:
  endpoints:
    web:
      exposure:
        include: "*"

6.4.测试❤️❤️

1.启动eureka集群,config配置中心3344,服务3355,服务3366。

2.手动刷新服务3344,一刷新处处生效

2.在gitee上修改版本号,浏览器查看3344,3355,3366. 

springCould中的Bus-从小白开始【11】_第3张图片

springCould中的Bus-从小白开始【11】_第4张图片

springCould中的Bus-从小白开始【11】_第5张图片

springCould中的Bus-从小白开始【11】_第6张图片

7.定点通知❤️❤️

  • 不想全部通知,只想顶点通知3355,不通知3366

公式:

http://localhost:配置中心的端口号/actuator/bus-refresh/{destination)

 至此消息总线基本拿捏~

springCould中的Bus-从小白开始【11】_第7张图片 springCould中的Bus-从小白开始【11】_第8张图片

你可能感兴趣的:(后端,idea,java,分布式,架构,中间件,rabbitmq)