当前位置: 首页 > article >正文

Dubbo相关的问题

Dubbo 失败机制

Dubbo 是一个 RPC 框架,它为我们的应用提供了远程通信能力的封装,同时,Dubbo 在 RPC 通信的基础上,逐步在向一个生态在演进,它涵盖了服务注册、动态路由、容错、服务降级、负载均衡等能力,基本上在微服务架构下面临的问题,Dubbo 都可以解决。

而对于 Dubbo 服务请求失败的场景,默认提供了重试的容错机制,也就是说,如果基于 Dubbo 进行服务间通信出现异常,服务消费者会对服务提供者集群中其他的节点发起重试,确保这次请求成功,默认的额外重试次数是 2 次。

除此之外,Dubbo 还提供了更多的容错策略,我们可以根据不同的业务场景来进行选择。

1. 快速失败策略,服务消费者只发起一次请求,如果请求失败,就直接把错误抛出去。这种比较适合在非幂等性场景中使用。
2. 失败安全策略,如果出现服务通信异常,直接把这个异常吞掉不做任何处理。并且返回⼀个空。
3. 失败自动恢复策略,后台记录失败请求,然后通过定时任务来对这个失败的请求进行重发。通常⽤于消息通知操作。
4. 并行调用多个服务策略,就是把这个消息广播给服务提供者集群,只要有任何一个节点返回,就表示请求执行成功。
5. 广播调用策略,逐个调用服务提供者集群,只要集群中任何一个节点出现异常,就表示本次请求失败。
6. 失败重试:调⽤失败后基于retries属性重试其它服务器,这是默认的机制,重试默认2次。---------默认

要注意的是,默认基于【重试策略】的容错机制中,需要注意幂等性的处理,否则在事务型的操作中,容易出现多次数据变更的问题。


http://www.kler.cn/a/148343.html

相关文章:

  • Vulnhub靶场案例渗透[8]- HackableII
  • Pytest-Bdd-Playwright 系列教程(9):datatable 参数的使用
  • 【mysql的当前读和快照读】
  • MySQL:数据库的约束
  • 【数据价值化】国有企业数据资产入表及估值实践指南:挖掘数字资产新价值
  • 工作和学习遇到的技术问题
  • 前端开发学习 (三) 列表功能
  • 【开源】基于JAVA的森林火灾预警系统
  • C++进阶篇5---番外-位图和布隆过滤器
  • 带着GPT-4V(ision)上路,自动驾驶新探索
  • 计算虚拟化之CPU——qemu解析
  • 距离向量路由协议——IGRP和EIGRP
  • Modown主题v8.12 安装教程和主题下载
  • 促进高层次人才创新创业,长沙又在“放大招”
  • uniapp使用map标签
  • 淼一科技为互联网企业销毁硬盘数据 拆除机房设备
  • Hive进阶函数:inline() 和 struct() ,一列转多行
  • git stash
  • 方舟笔记:方舟开发框架概述
  • Open3D (C++) 计算两点云之间的最小距离
  • 十八、初识elasticsearsh (索引)
  • vue 通过ref调用router-view子组件的方法
  • 函数版 → 求小于给定整数的最大素数 ← Python
  • Oracle的安装及使用流程
  • Java中的mysql——面试题+答案(数据库连接池,批处理操作)——第22期
  • 每日一题(LeetCode)----哈希表--快乐数