Spring Cloud Bus——概述与基本配置

server/2024/10/18 14:25:23/

在微服务架构中,多个服务之间的配置管理和事件通知是一个重要的需求。Spring Cloud Bus 提供了一个轻量级的消息总线,用于在分布式系统中传播配置变化和事件通知。它能够与 Spring Cloud Config 一起工作,实现配置的实时刷新。在这篇文章中,我们将详细介绍 Spring Cloud Bus 的基本概念以及如何进行基本配置。

一、Spring Cloud Bus 概述

Spring Cloud Bus 是一个基于消息代理的轻量级事件总线,主要用于在分布式系统中传播事件和状态变化。它可以与多种消息中间件(如 RabbitMQ、Kafka)集成,将配置变化或其他事件广播到所有相关的服务实例,从而实现分布式系统的协同工作。

主要功能
  1. 配置刷新:当配置中心的配置发生变化时,自动将变化通知到所有相关服务实例,实现配置的实时刷新。
  2. 事件传播:在微服务之间传播自定义事件,实现服务间的通信和协作。

二、Spring Cloud Bus 基本配置

要使用 Spring Cloud Bus,需要在项目中添加相关的依赖。以下是一个典型的 Spring Boot 项目配置文件 pom.xml,包括 Spring Cloud Bus 和消息中间件(例如 RabbitMQ)的依赖:

<dependencies><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><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-config-client</artifactId></dependency>
</dependencies>

三、配置 RabbitMQ

Spring Cloud Bus 需要一个消息代理来传播消息。以 RabbitMQ 为例,你需要在 application.yml 中配置 RabbitMQ 的连接信息:

spring:rabbitmq:host: localhostport: 5672username: guestpassword: guestspring:cloud:bus:enabled: trueconfig:uri: http://localhost:8888  # 配置中心的地址

四、启用 Spring Cloud Bus

在 Spring Boot 主应用类中启用 Spring Cloud Bus 功能:

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.client.discovery.EnableDiscoveryClient;@SpringBootApplication
@EnableDiscoveryClient
public class BusApplication {public static void main(String[] args) {SpringApplication.run(BusApplication.class, args);}
}

五、测试配置刷新

当配置中心的配置发生变化时,可以通过以下方式触发配置刷新:

  1. 手动刷新:通过 POST 请求触发配置刷新。例如:
curl -X POST http://localhost:8080/actuator/bus-refresh
  1. 自动刷新:当配置中心的配置变化时,自动发送消息通知所有相关服务实例。

application.yml 中配置管理端点:

management:endpoints:web:exposure:include: bus-refresh

完成上述配置后,当配置中心的配置发生变化时,你可以通过 POST 请求触发配置刷新,所有相关的服务实例都会接收到刷新通知并更新配置。


http://www.ppmy.cn/server/49767.html

相关文章

React@16.x(25)useReducer

目录 1&#xff0c;介绍1.1&#xff0c;Flux 的设计思想 2&#xff0c;实现2.1&#xff0c;引入2.2&#xff0c;实现 useReducer 3&#xff0c;官方实现 1&#xff0c;介绍 这也是官方的一个HOOK&#xff0c;目的是更方便的使用 Redux。 Redux 后续会详细介绍。它的主体思想沿…

金鸣识别系统:PDF转Excel的高效利器

在日常办公中&#xff0c;我们经常需要将PDF文档转换为Excel表格以便进行数据分析。然而&#xff0c;当有些PDF转换过程可能会变得复杂&#xff0c;因为许多转换工具无法完美处理图片元素&#xff0c;导致转换后的准确率不高或排版错乱。幸运的是&#xff0c;金鸣识别系统以其卓…

计算机跨考现状,两极分化现象很严重

其实我觉得跨考计算机对于一些本科学过高数的同学来说有天然的优势 只要高数能学会&#xff0c;那计算机那几本专业课&#xff0c;也能很轻松的拿下&#xff0c;而对于本科是文科类的专业&#xff0c;如果想跨考计算机&#xff0c;难度就不是一般的大了。 现在跨考计算机呈现…

一行超长日志引发的 “血案” - Containerd 频繁 OOM 背后的真相

案发现场&#xff1a;混沌初现 2024年6月10日&#xff0c;本应是平静的一天。但从上午 9 点开始&#xff0c;Sealos 公有云的运维监控告警就开始不停地响。北京可用区服务器节点突然出现大量 “not ready” 告警&#xff0c;紧接着&#xff0c;系统自动触发 004 节点重启&…

简单的心电图信号分割方法

代码很简单&#xff0c;很容易看懂。 import pandas as pdimport matplotlib.pyplot as plt #headers [Name, Age, Marks]df pd.read_csv(samples-folder/samples2.csv) dfdf.drop(0)dfdf.drop(1)# print(df) if(len(df.columns) 3): df.columns [sample interval, sig…

GStreamer 源码编译,在 Clion 下搭建调试环境

前言 最近在学习 GStreamer&#xff0c;官方提供了一些教程&#xff0c;本人希望能够断点调试&#xff0c;以便学习代码逻辑。本文记录如何在 Clion 搭建 GStreamer 源码编译、调试环境 步骤 下载源码 git clone https://gitlab.freedesktop.org/gstreamer/gstreamer.gitCl…

几内亚ECTN是什么?怎么办理?建议收藏!

几内亚ECTN是什么&#xff1f;怎么办理&#xff1f;建议收藏&#xff01; 一、去往几内亚的货物&#xff0c;从六月一日开始强制实施ECTN制度&#xff0c;取消原来并行的ENS制度。如若货物到港前没申请ECTN&#xff0c;几内亚海关将会强行扣货。 ECTN是英文&#xff1a;ELECTR…

Java中管理数据的方式

在Java中&#xff0c;管理数据的方式多种多样&#xff0c;取决于具体的应用需求和场景。下面详细介绍几种常见的数据管理方式&#xff0c;包括内存管理、文件管理、数据库管理以及其他高级数据管理技术。 1. 内存管理 1.1 基本数据类型和对象 Java提供了多种基本数据类型&am…