热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

SpringCloud之Bus(消息总线)

说明:关于SpringCloud系列的文章中的代码都在码云上面地址:https:gitee.comzh_0209_javaspringcloud-ali

说明:关于SpringCloud系列的文章中的代码都在码云上面
地址:https://gitee.com/zh_0209_java/springcloud-alibaba.git


简介

Spring Cloud Bus 配置 Spring Cloud Config 使用可以实现配置的动态刷新。
在这里插入图片描述
Spring Cloud Bus 是用来将分布式系统的节点与轻量级消息系统链接起来的框架,他整合了Java的事件处理机制和消息中间件的功能

Bus 支持两种消息代理:RabbitMQKafka


作用

Spring Cloud Bus 能管理和传播分布式系统间的消息,就像一个分布式执行器,可用于广播状态更改,事件推送等,也可以当做微服务间的通信通道。

在这里插入图片描述


为什么被称之为总线?



  • 什么是总线?
    在微服务架构的系统中,通常会使用轻量级的消息代理来构架一个共用的消息主题,并让系统中所有微服务实例都连接上来。由于该主题中产生的消息会被所有实例监听和消费,所以称他为消息总线

基本原理

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


修改3344服务

  1. 新增pom依赖


<dependency><groupId>org.springframework.cloudgroupId><artifactId>spring-cloud-starter-bus-amqpartifactId>
dependency>

  1. 修改配置文件

server:port: 3344
spring:application:name: cloud-config-center # 注册进eureka服务器的微服务名cloud:config:server:git:uri: https://gitee.com/zh_0209_java/springcloud-config.git # 远程仓库上配置文件的地址label: master # 读取的分支# rabbitmq 相关配置rabbitmq:host: 10.10.11.21port: 5672username: guestpassword: guest# &#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61; eureka client &#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;
eureka:# 设置控制台显示的服务路径instance:instance-id: configCenter3344prefer-ip-address: true # 访问地址可以显示ip# Eureka客户端向服务端发送心跳的时间间隔&#xff0c;单位为秒&#xff08;默认是30秒&#xff09;lease-renewal-interval-in-seconds: 1# Eureka 服务端在收到最后一次心跳后等待时间上线&#xff0c;单位为秒&#xff08;默认是90秒&#xff09;&#xff0c;超时将剔除服务lease-expiration-duration-in-seconds: 2client:# 表示是否将自己注册进eurekaServer,默认为trueregister-with-eureka: true# 是否从EurekaServer抓取已有的注册信息&#xff0c;默认为true.单节点无所谓&#xff0c;集群必须设置为true才能配合ribbon使用负载均衡fetchRegistry: trueservice-url:# 本机入住eurekaServer 地址defaultZone: http://localhost:7001/eureka # 单机版
# defaultZone: http://localhost:7001/eureka,http://localhost:7002/eureka # 集群版# 暴露bus刷新配置的端点
management:endpoints:web:exposure:include: &#39;bus-refresh&#39;

修改3355服务

  1. 新增pom依赖


<dependency><groupId>org.springframework.cloudgroupId><artifactId>spring-cloud-starter-bus-amqpartifactId>
dependency>

  1. 修改配置文件

server:port: 3355spring:application:name: config-clientcloud:config:label: master # 读取的分支name: config # 配置文件名称profile: dev # 读取后缀名称&#xff0c;上述3个综合条件&#xff1a;master分支上config-dev.yml的配置文件被读取uri: http://localhost:3344 # 配置中心地址rabbitmq:host: 10.10.11.21port: 5672username: guestpassword: guest
# &#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61; eureka client &#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;
eureka:# 设置控制台显示的服务路径instance:instance-id: configClient3355prefer-ip-address: true # 访问地址可以显示ip# Eureka客户端向服务端发送心跳的时间间隔&#xff0c;单位为秒&#xff08;默认是30秒&#xff09;lease-renewal-interval-in-seconds: 1# Eureka 服务端在收到最后一次心跳后等待时间上线&#xff0c;单位为秒&#xff08;默认是90秒&#xff09;&#xff0c;超时将剔除服务lease-expiration-duration-in-seconds: 2client:# 表示是否将自己注册进eurekaServer,默认为trueregister-with-eureka: true# 是否从EurekaServer抓取已有的注册信息&#xff0c;默认为true.单节点无所谓&#xff0c;集群必须设置为true才能配合ribbon使用负载均衡fetchRegistry: trueservice-url:# 本机入住eurekaServer 地址defaultZone: http://localhost:7001/eureka # 单机版
# defaultZone: http://localhost:7001/eureka,http://localhost:7002/eureka # 集群版# 暴露监控端点
management:endpoints:web:exposure:include: "*"

启动eureka&#xff0c;3344,3355 进行测试

当修改完远程仓库的配置文件后&#xff0c;向3344发送一个POST请求 curl -X POST "http://localhost:3344/actuator/bus-refresh",在访问3355&#xff0c;即可发现自动更新了配置&#xff0c;这样的好处就是&#xff0c;向配置服务端发送一个post请求&#xff0c;可以更新所有客户端的请求。


bus动态刷新定点通知

比如我们现在还有一个客户端3366&#xff0c;当我们更新了配置&#xff0c;想只刷新3355&#xff0c;而不更新3366&#xff0c;这时候就需要定点通知

公式&#xff1a; http://localhost:3344/actuator/bus-refresh/{destination}

通过destination 参数指定需要更新配置的服务或实例&#xff0c;

destination 的取值就是 {spring.application.name} [: {port}]

比如我想只刷新3355&#xff0c;那么就发送这样一个POST请求curl -X POST http://localhost:3344/actuator/bus-refresh/config-client:3355


推荐阅读
  • 本文详细介绍了如何在 Spring Boot 应用中通过 @PropertySource 注解读取非默认配置文件,包括配置文件的创建、映射类的设计以及确保 Spring 容器能够正确加载这些配置的方法。 ... [详细]
  • 本文详细介绍了如何在Linux系统上安装和配置Smokeping,以实现对网络链路质量的实时监控。通过详细的步骤和必要的依赖包安装,确保用户能够顺利完成部署并优化其网络性能监控。 ... [详细]
  • CentOS7源码编译安装MySQL5.6
    2019独角兽企业重金招聘Python工程师标准一、先在cmake官网下个最新的cmake源码包cmake官网:https:www.cmake.org如此时最新 ... [详细]
  • 数据库内核开发入门 | 搭建研发环境的初步指南
    本课程将带你从零开始,逐步掌握数据库内核开发的基础知识和实践技能,重点介绍如何搭建OceanBase的开发环境。 ... [详细]
  • 深入解析Spring Cloud Ribbon负载均衡机制
    本文详细介绍了Spring Cloud中的Ribbon组件如何实现服务调用的负载均衡。通过分析其工作原理、源码结构及配置方式,帮助读者理解Ribbon在分布式系统中的重要作用。 ... [详细]
  • 如何配置Unturned服务器及其消息设置
    本文详细介绍了Unturned服务器的配置方法和消息设置技巧,帮助用户了解并优化服务器管理。同时,提供了关于云服务资源操作记录、远程登录设置以及文件传输的相关补充信息。 ... [详细]
  • 使用Vultr云服务器和Namesilo域名搭建个人网站
    本文详细介绍了如何通过Vultr云服务器和Namesilo域名搭建一个功能齐全的个人网站,包括购买、配置服务器以及绑定域名的具体步骤。文章还提供了详细的命令行操作指南,帮助读者顺利完成建站过程。 ... [详细]
  • 在现代网络环境中,两台计算机之间的文件传输需求日益增长。传统的FTP和SSH方式虽然有效,但其配置复杂、步骤繁琐,难以满足快速且安全的传输需求。本文将介绍一种基于Go语言开发的新一代文件传输工具——Croc,它不仅简化了操作流程,还提供了强大的加密和跨平台支持。 ... [详细]
  • 从零开始构建完整手机站:Vue CLI 3 实战指南(第一部分)
    本系列教程将引导您使用 Vue CLI 3 构建一个功能齐全的移动应用。我们将深入探讨项目中涉及的每一个知识点,并确保这些内容与实际工作中的需求紧密结合。 ... [详细]
  • 本文详细记录了在银河麒麟操作系统和龙芯架构上使用 Qt 5.15.2 进行项目打包时遇到的问题及解决方案,特别关注于 linuxdeployqt 工具的应用。 ... [详细]
  • VSCode与Gitee集成:项目提交的高效实践
    本文介绍如何利用VSCode内置的Git工具将项目提交到Gitee,简化Git命令的使用,提升代码管理效率。同时分享一些常见的踩坑经验和解决方案。 ... [详细]
  • Scala 实现 UTF-8 编码属性文件读取与克隆
    本文介绍如何使用 Scala 以 UTF-8 编码方式读取属性文件,并实现属性文件的克隆功能。通过这种方式,可以确保配置文件在多线程环境下的一致性和高效性。 ... [详细]
  • Composer Registry Manager:PHP的源切换管理工具
    本文介绍了一个用于Composer的源切换管理工具——Composer Registry Manager。该项目旨在简化Composer包源的管理和切换,避免与常见的CRM系统混淆,并提供了详细的安装和使用指南。 ... [详细]
  • 基于KVM的SRIOV直通配置及性能测试
    SRIOV介绍、VF直通配置,以及包转发率性能测试小慢哥的原创文章,欢迎转载目录?1.SRIOV介绍?2.环境说明?3.开启SRIOV?4.生成VF?5.VF ... [详细]
  • 本文探讨了 Spring Boot 应用程序在不同配置下支持的最大并发连接数,重点分析了内置服务器(如 Tomcat、Jetty 和 Undertow)的默认设置及其对性能的影响。 ... [详细]
author-avatar
立行谏圣
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有