谈谈对dubbo的广播机制的理解
目录
1、介绍
1.1、广播调用
1、工作原理
1.2、调用方式
1、@Reference 注解
2、XML 配置
3、全局配置
1.3、 广播机制的特性
2、重试机制
2.1、默认行为
2.2、自定义逻辑
1、在业务层封装重试逻辑
2、使用 @Reference
3、广播调用的实践
3.1、常用参数
1. XML 配置示例
2. 注解配置示例
3. 代码配置示例
3.2、集群策略
3.3、幂等性设计
1、原因
2、解决方案
4、使用场景
5、注意事项
前言
在dubbo中协议端口默认为20880,注册中心zookeeper默认端口为2181。
zookeeper类似于电话簿,dubbo类似于电话号码。
两者关系如下图所示:
在分布式系统中,服务的高可用性和容错能力是确保系统稳定性的重要因素。Dubbo 作为一个高性能的 RPC 框架,提供了多种集群容错策略,来应对分布式服务调用中的各种异常情况。
其中,Broadcast Cluster (广播集群) 是一种特殊的策略,它能够将请求广播给所有的服务提供者,并要求所有服务都必须成功执行。
关于更多dubbo的介绍:深入探讨dubbo组件的实践_dubbo 分层-CSDN博客
1、介绍
在 Apache Dubbo 中,广播调用(Broadcast) 是一种特殊的调用模式,它将请求发送到所有注册的服务提供者(Provider),每个提供者都会独立执行该调用。
这种模式常用于通知所有服务实例执行某些操作(如刷新缓存、更新配置等)。
以下是关于 Dubbo 广播调用中重试机制(retries
配置)的详细说明:
1.1、广播调用
广播调用(Broadcast) 是一种特殊的远程调用模式,其核心特点是:将请求发送到所有注册的服务提供者(Provider),每个提供者独立执行该调用。
1、工作原理
Broadcast(广播)集群容错策略在 Dubbo 中是指将请求广播给所有的服务提供者,并逐一调用它们。只有当所有的服务提供者都成功执行请求时,调用才被认为是成功的。
如果任何一个服务提供者执行失败,则整个调用会抛出异常。
具体的工作原理如下:
请求广播:
当服务消费者发起一个 RPC 请求时,Dubbo 会将这个请求广播到所有注册的服务提供者。
逐一调用:
每一个服务提供者都会接收到这个请求,并按照顺序执行请求中的操作。
返回结果:
如果所有的服务提供者都成功执行了请求,Dubbo 会返回成功的响应。如果有任何一个服务提供者执行失败,Dubbo 将抛出异常,并停止后续的调用。
这种策略确保了所有服务提供者的操作保持一致,适用于需要全局一致性的场景。
1.2、调用方式
1、@
Reference 注解
通过
@
Reference 注解的 cluster 属性设置为 boradcast。
代码示例:
@Reference(cluster = "broadcast", timeout = 3000)
private DemoService demoService;
2、XML 配置
代码示例:
<dubbo:reference id="demoService" interface="com.example.DemoService"cluster="broadcast"timeout="3000" />
-
行为特点:
- 请求会发送到所有服务提供者(Provider)。
- 每个 Provider 独立执行调用,互不干扰。
- 如果任何一个调用失败,Dubbo 会记录失败信息,但不会自动重试。
3、全局配置
可以通过全局配置dubbo.properties方式指定使用 Broadcast 策略:
dubbo.reference.cluster=broadcast
这种方式适用于需要全局统一使用 Broadcast 策略的场景。
1.3、 广播机制的特性
1.多实例并发调用
广播调用会将请求发送到所有注册的服务提供者(Provider),每个实例独立执行操作。
2.无顺序性
广播调用不保证执行顺序,多个实例可能同时处理同一请求。
3.无自动重试
Dubbo 默认不为广播调用的每个 Provider 提供重试机制,但业务层可能手动实现重试。
2、重试机制
2.1、默认行为
1、无自动重试:
Dubbo 的广播调用默认不支持自动重试。即使某个 Provider 调用失败(如网络异常),也不会对该 Provider 重新尝试调用。
2、失败处理策略:
广播调用的失败处理由 cluster 策略决定,默认是 failover(失败自动切换)或 failfast(快速失败)。但在广播模式下,cluster 配置被强制设置为 boradcast,因此失败处理策略被覆盖。
2.2、自定义逻辑
如果需要为广播调用的每个 Provider 添加重试机制,需要通过以下方式实现:
1、在业务层封装重试逻辑
public void broadcastWithRetry() {List<Invoker<DemoService>> invokers = registry.getInvokers();for (Invoker<DemoService> invoker : invokers) {int retries = 3;while (retries > 0) {try {invoker.invoke(new RpcInvocation("sayHello", new Object[] { "world" }));break; // 成功则跳出循环} catch (Exception e) {retries--;if (retries == 0) {// 记录失败日志或抛出异常log.error("Broadcast call failed after retries: {}", e.getMessage());}}}}
}
2、使用 @
Reference
retries 参数(不推荐)。
限制:@
Reference 的 retries 参数仅对单个调用生效,无法直接应用于广播调用。
替代方案:结合 retries 和自定义负载均衡策略,但需要谨慎处理。
3、广播调用的实践
3.1、常用参数
如下图所示:
1. XML 配置示例
1、服务提供者配置
<!-- dubbo.xml -->
<dubbo:service interface="com.example.DemoService"ref="demoServiceImpl"timeout="3000" <!-- 超时时间(毫秒) -->retries="2" <!-- 失败重试次数(仅在 cluster=failover 时生效) -->loadbalance="roundrobin" <!-- 负载均衡策略 -->cluster="failover" <!-- 集群容错策略 -->
/>
2、服务消费者配置
<!-- dubbo.xml -->
<dubbo:reference id="demoService"interface="com.example.DemoService"timeout="5000" <!-- 超时时间(毫秒) -->retries="1" <!-- 失败重试次数 -->loadbalance="random" <!-- 负载均衡策略 -->cluster="failfast" <!-- 集群容错策略 -->
/>
3、全局配置(默认值)
<!-- dubbo.xml -->
<dubbo:provider timeout="2000"retries="0"loadbalance="random"cluster="failover"
/>
<dubbo:consumer timeout="1000"retries="0"loadbalance="random"cluster="failover"
/>
2. 注解配置示例
1、服务提供者
@Service(timeout = 3000, retries = 2, loadbalance = "roundrobin", cluster = "failover")
public class DemoServiceImpl implements DemoService {@Overridepublic String sayHello(String name) {return "Hello, " + name;}
}
2、服务消费者
@Reference(timeout = 5000, retries = 1, loadbalance = "random", cluster = "failfast")
private DemoService demoService;
3. 代码配置示例
1、服务提供者
ServiceConfig<DemoService> service = new ServiceConfig<>();
service.setInterface(DemoService.class);
service.setRef(new DemoServiceImpl());
service.setTimeout(3000); // 超时时间
service.setRetries(2); // 重试次数
service.setLoadbalance("roundrobin"); // 负载均衡
service.setCluster("failover"); // 集群策略
service.export();
2、服务消费者
ReferenceConfig<DemoService> reference = new ReferenceConfig<>();
reference.setInterface(DemoService.class);
reference.setTimeout(5000); // 超时时间
reference.setRetries(1); // 重试次数
reference.setLoadbalance("random"); // 负载均衡
reference.setCluster("failfast"); // 集群策略
DemoService demoService = reference.get();
3.2、集群策略
超时时间单位:
timeout
的单位是 毫秒(ms),需根据业务需求合理设置。
1、负载均衡策略:
random
:随机选择(默认)。
roundrobin
:轮询。
leastactive
:最少活跃调用者优先。
consistenthash
:一致性哈希(需额外配置)。
2、集群策略:
failover
:失败自动切换(重试其他节点)。
failfast
:快速失败(立即抛出异常)。
failsafe
:失败安全(忽略异常,返回空结果)。
failback
:失败自动恢复(异步重试)。
forking
:并行调用多个节点(需配置 forks
)。
3.3、幂等性设计
1、原因
1.网络不可靠导致请求重复
- 场景:消费者(Consumer)发送广播请求后,部分 Provider 因网络问题未收到响应,Consumer 可能重发请求。
- 问题:若接口非幂等,重复请求会导致重复操作(如多次写入数据库、多次触发任务)。
2.服务实例重启或故障恢复
- 场景:某个 Provider 在处理广播请求时发生故障,重启后可能重新处理未完成的请求。
- 问题:若接口非幂等,重启后重复执行可能导致数据不一致。
3.广播调用的重试逻辑
- 场景:业务层为广播调用添加重试逻辑(如失败后重试特定 Provider)。
- 问题:若接口非幂等,重试会导致重复操作。
4.多线程并发执行
- 场景:多个线程并发调用广播接口,或多个广播请求同时触发。
- 问题:若接口非幂等,可能导致资源竞争或数据冲突。
2、解决方案
1、唯一标识符(Request ID):
为每个广播请求分配唯一 ID,服务端通过检查 ID 判断是否已处理过该请求。
public void refreshCache(String requestId) {if (cacheService.isProcessed(requestId)) {return; // 已处理,直接返回}// 执行刷新缓存逻辑cacheService.markAsProcessed(requestId);
}
2、状态检查与更新:
在操作前检查目标状态,避免重复修改。
public void updateStatus(String resourceId, String newStatus) {String currentStatus = db.getStatus(resourceId);if (currentStatus.equals(newStatus)) {return; // 状态一致,无需更新}db.updateStatus(resourceId, newStatus);
}
3、去重表(Deduplication Table):
使用数据库表记录已处理的请求 ID,防止重复处理。
CREATE TABLE deduplication (request_id VARCHAR(36) PRIMARY KEY,processed_at TIMESTAMP
);
举例:客户端与服务端协作
1.客户端:生成唯一请求 ID 并传递给服务端。
String requestId = UUID.randomUUID().toString();
demoService.broadcastRefreshCache(requestId);
2.服务端:基于请求 ID 实现幂等性校验。
@Service
public class CacheServiceImpl implements CacheService {private final Set<String> processedRequests = new HashSet<>();@Overridepublic void refreshCache(String requestId) {if (processedRequests.contains(requestId)) {return;}// 执行刷新逻辑processedRequests.add(requestId);}
}
经过上面的示例,可以得出:
4、使用场景
1、通知所有服务实例
例如,更新分布式缓存、关闭资源、触发定时任务等。
2、配置同步
在分布式系统中,有时需要将某些配置信息同步到所有节点。例如,在分布式缓存或数据库集群中,更新配置时需要确保所有节点都接收到并执行这个更新操作。
3、全局状态更新
当系统中的全局状态需要在多个服务提供者之间保持一致时,Broadcast 策略能够确保所有服务提供者都执行了相同的操作。
4、多节点数据一致性
在某些场景下,多个服务节点的数据需要保持一致,例如在分布式文件系统中,删除某个文件时需要确保所有节点都删除该文件。
5、注意事项
- 性能开销:
广播调用会向所有 Provider 发送请求,可能导致性能下降。需合理控制调用频率。 - 幂等性要求:
由于调用可能重复或失败,服务接口必须设计为幂等的(Idempotent)。 - 失败容忍:
广播调用不保证所有 Provider 成功执行,需在业务层处理部分失败的情况。
总结
- 广播调用(
boradcast
)是 Dubbo 的特殊调用模式,用于通知所有服务实例。 - 默认不支持重试:广播调用的每个 Provider 调用失败时,Dubbo 不会自动重试。
- 自定义重试:需在业务层显式实现重试逻辑,或结合负载均衡策略。
- 适用场景:适用于需要通知所有服务实例的场景,但需注意性能和幂等性。
相关文章:

谈谈对dubbo的广播机制的理解
目录 1、介绍 1.1、广播调用 1、工作原理 1.2、调用方式 1、Reference 注解 2、XML 配置 3、全局配置 1.3、 广播机制的特性 2、重试机制 2.1、默认行为 2.2、自定义逻辑 1、在业务层封装重试逻辑 2、使用 Reference 3、广播调用的实践 3.1、常用参数 1.…...
对接钉钉消息样例:DING消息、机器人
一、钉钉开放平台配置信息 private static String robotCode private static String appkey private static String appsecret private static Long agentId 二、钉钉开放平台token、用户信息 public static Client createClient() throws Exception {Config config n…...

003-类和对象(二)
类和对象(二) 1. 类的6个默认成员函数 如果一个类中什么成员都没有,简称为空类。 空类中真的什么都没有吗?并不是,任何类在什么都不写时,编译器会自动生成以下6个默认成员函数。 默认成员函数ÿ…...
使用Rancher在CentOS 环境上部署和管理多Kubernetes集群
引言 随着容器技术的迅猛发展,Kubernetes已成为容器编排领域的事实标准。然而,随着企业应用规模的扩大,多集群管理逐渐成为企业IT架构中的重要需求。 Rancher作为一个开源的企业级多集群Kubernetes管理平台,以其友好的用户界面和…...
Java常用数据结构底层实现原理及应用场景
一、线性结构 1. ArrayList 底层实现:动态数组(Object[] elementData)。 核心特性: 默认初始容量为 10,扩容时容量增长为原来的 1.5 倍(int newCapacity oldCapacity (oldCapacity >> 1)…...
利用朴素贝叶斯对UCI 的 mushroom 数据集进行分类
朴素贝叶斯(Naive Bayes)是一种基于贝叶斯定理的简单而有效的分类算法,特别适合处理文本分类和多类别分类问题。UCI的Mushroom数据集是一个经典的分类数据集,包含蘑菇的特征和类别(可食用或有毒)。 1. 数据…...

Linux火墙管理及优化
网络环境配置 使用3个新的虚拟机【配置好软件仓库和网络的】 F1 192.168.150.133 NAT F2 192.168.150.134 192.168.10.20 NAT HOST-ONLY 网络适配仅主机 F3 192.168.10.30 HOST-ONLY 网络适配仅主机 1 ~]# hostnamectl hostname double1.timinglee.org 【更…...

Visual Studio 制作msi文件环境搭建
一、插件安装 a. 插件寻找 在 Visual Studio 2017 中,如果你希望安装用于创建 MSI 安装包的插件,第一步是:打开 Visual Studio 后,点击顶部菜单栏中的 “工具”(Tools),然后选择下拉菜单中的 “…...
(Java基础笔记vlog)Java中常见的几种设计模式详解
前言: 在 Java 编程里,设计模式是被反复使用、多数人知晓、经过分类编目的代码设计经验总结。他能帮助开发者更高效地解决常见问题,提升代码的可维护性、可扩展性和复用性。下面介绍Java 中几种常见的设计模式。 单例模式(Singlet…...
C++ vector 深度解析:从原理到实战的全方位指南
一、引言 在 C 编程中,我们经常需要处理一组数据。比如,你想存储一个班级所有学生的成绩,或者保存用户输入的一组数字。最容易想到的方法是使用数组: int scores[100]; // 定义一个能存储100个成绩的数组但数组有两个明显的缺点…...

鸿蒙进阶——Framework之Want 隐式匹配机制概述
文章大纲 引言一、Want概述二、Want的类型1、显式Want2、隐式Want3、隐式Want的匹配 三、隐式启动Want 源码概述1、有且仅有一个Ability匹配2、有多个Ability 匹配需要弹出选择对话框3、ImplicitStartProcessor::ImplicitStartAbility3.1、GenerateAbilityRequestByAction3.1.1…...

antv/g6 图谱封装配置(二)
继上次实现图谱后,后续发现如果要继续加入不同样式的图谱实现起来太过麻烦,因此考虑将配置项全部提取封装到js文件中,图谱组件只专注于实现各种不同的组件,其中主要封装的点就是各个节点的横坐标(x),纵坐标…...

OpenCV CUDA模块图像过滤------用于创建一个最小值盒式滤波器(Minimum Box Filter)函数createBoxMinFilter()
操作系统:ubuntu22.04 OpenCV版本:OpenCV4.9 IDE:Visual Studio Code 编程语言:C11 算法描述 该函数创建的是一个 最小值滤波器(Minimum Filter),它对图像中每个像素邻域内的像素值取最小值。常用于&…...

网络抓包命令tcpdump及分析工具wireshark使用
文章目录 环境文档用途详细信息 环境 系统平台:Linux x86-64 Red Hat Enterprise Linux 8,Linux x86-64 Red Hat Enterprise Linux 7,Linux x86-64 SLES 12,银河麒麟 (鲲鹏),银河麒麟 (X86_64),银河麒麟(龙…...
linux strace调式定位系统问题
strace 的基本功能 strace 的主要功能包括: 跟踪系统调用:显示进程执行时调用的系统函数及其参数和返回值。监控信号:记录进程接收到的信号。性能分析:统计系统调用的执行时间和次数。调试支持:帮助定位程序崩溃、性…...
femap许可与云计算集成
随着云计算技术的迅猛发展,越来越多的企业开始将关键应用和服务迁移到云端,以享受其带来的弹性扩展、高效管理和成本优化等优势。Femap作为一款强大的电磁仿真工具,通过与云计算的集成,将为企业带来前所未有的许可管理和仿真分析体…...

车载诊断架构 --- 车载诊断有那些内容(上)
我是穿拖鞋的汉子,魔都中坚持长期主义的汽车电子工程师。 老规矩,分享一段喜欢的文字,避免自己成为高知识低文化的工程师: 钝感力的“钝”,不是木讷、迟钝,而是直面困境的韧劲和耐力,是面对外界噪音的通透淡然。 生活中有两种人,一种人格外在意别人的眼光;另一种人无论…...

【Hadoop】大数据技术之 HDFS
目录 一、HDFS 概述 1.1 HDFS 产出背景及定义 1.2 HDFS 优缺点 1.3 HDFS 组成架构 1.4 HDFS 文件块大小 二、HDFS 的Shell 操作 三、HDFS 的读写流程(面试重点) 3.1 HDFS 写数据流程 3.2 HDFS 读数据流程 四、DataNode 4.1 DataNode 的工作机制…...

聊一下CSS中的标准流,浮动流,文本流,文档流
在网络上关于CSS的文章中,有时候能听到“标准流”,“浮动流”,“定位流”等等词语,还有像“文档流”,“文本流”等词,这些流是什么意思?它们是CSS中的一些布局方案和特性。今天我们就来聊一下CS…...

ATGM332D-F8N22单北斗多频定位导航模块
ATGM332D-F8N 系列模块是 12.216mm 尺寸的高性能单北斗多频定位导航模块。该系列模块产品基于中科微新一代 SOC 单北斗多频芯片 AT9880B,支持北斗二号和北斗三号的 B1I、B1C、B2I、B3I、B2a 和 B2b 频点信号。 主要特征 多频点单北斗接收机 支持北斗二号、北斗三号…...

2024年热门AI趋势及回顾
人工智能的崛起 2024 年可能会被铭记为人工智能不再是一种技术新奇事物,而是成为现实的一年。微软、Salesforce 和 Intuit 等巨头将人工智能融入主流企业解决方案;从文案写作到数据分析,专门的人工智能应用程序和服务如雨后春笋般涌现&#…...
【信息系统项目管理师】第20章:高级项目管理 - 28个经典题目及详解
更多内容请见: 备考信息系统项目管理师-专栏介绍和目录 文章目录 【第1题】【第2题】【第3题】【第4题】【第5题】【第6题】【第7题】【第8题】【第9题】【第10题】【第11题】【第12题】【第13题】【第14题】【第15题】【第16题】【第17题】【第18题】【第19题】【第20题】【第…...

3. OpenManus-RL中使用AgentGym建立强化学习环境
AgentGym概述 AgentGym是为评估和开发大模型agent而设计的支持多环境和多任务的框架。该框架统一采用ReAct格式,提供多样化的交互环境和任务,支持实时反馈和并发操作。 What is Ai Agent(基于大模型的智能体)? 首先是人造实体&…...

C++性能测试工具——sysprof的使用
一、sysprof sysprof相对于前面的一些性能测试工具来说,要简单不少。特别是其图形界面的操作,非常容易上手,它还支持分析文件的保存和导入功能,这是一个非常不错的功能。做为一款系统性能测试工具,它支持多种硬件平台…...
JavaScript性能优化实战(13):性能测试与持续优化
在前面的系列文章中,我们探讨了各种JavaScript性能优化的方法和实战案例。然而,优化工作不应仅是一次性的努力,而应当成为开发流程中的常态。本篇将聚焦于如何建立系统化的性能测试体系,并实现持续的性能优化机制,确保应用长期保持出色的性能表现。 前端性能测试体系构建…...
questions and answers_1
TCP 长连接和短连接有什么区别? TCP 短连接是指客户端与服务端连接后只进行一次读写就关闭连接,一般是客户端关闭。 而长连接则是指在进行完一次读写后不关闭连接,直到服务端压力过大则选择关闭一些长时间为进行读写的连接。 TCP 短连接的优…...

树莓派内核源码的下载,配置,编译和替换
共享文件夹的创建 ubuntu创建共享文件夹可以实现和本地windows跨系统文件共享 下面是创建步骤 先在windows准备一个文件夹来当做共享文件夹 树莓派内核源码下载 1.在树莓派终端输入以下指令查看内核版本 uname -r我这里是已经编译替换过后的版本 2.选择树莓派对应的版本号下…...

CentOS停止维护了,解决yum不能安装软件的问题
最近在使用CentOS的yum命令安装软件时,出现了如下错误: 原因: 这是因为CentOS在2024 年 6 月 30 日停止维护了,同时也移除了相关的软件镜像仓库,导致网站地址访问不了,从而下载不了软件。 解决方法…...

过压保护电路设计和计算
设备供电电压因各种原因变得过高会烧坏设备,因此可以在前级加过压保护电路。 稳压二极管+PMOS 电路分析 1、当输入电压 Vin < 5.1V 时:(下图以输入电压 Vin = 5V 举例) D1是5.1V稳压管,此时输入电压Vin才5V,小于5.1V,所以稳压管D1未进入稳压状态,不导通。 5.1V稳…...

20250523-BUG:无法加载“GameLib/Framework.h“头文件(已解决)
BUG:无法加载"GameLib/Framework.h"头文件(已解决) 最近在打开新的C项目时报了这个错,我是按照以下步骤来排除的BUG,希望对您有所帮助~ 检查【C/C】-【附加包含目录】中的路径有无问题,一般需要加…...