Dubbo服务容错
当一个服务调用另一个远程服务出现错误时的外观
Dubbo提供了多种容错方案,默认值为failover(重试)
1)、Failover Cluster(默认)
失败自动切换,当出现失败,重试其他服务器,通常用于读操作,但重试会带来更长延迟,可以通过属性retries来设置重试次数(不含第一次)
2)、Failfast Cluster
快速失败,只发起一次调用,失败立即报错,通常用于非幂等性的写操作,比如新增记录。
3)、Failsafe Cluster
失败安全,出现异常时,直接忽略,不做任何操作,通常用于写入审计日志等操作。
4)、Failback Cluster
失败自动重发,后台记录失败请求,定时重发,用于一些一定要成功的服务调用,例如消息通知等。
5)、Forking Cluster
并行调用多个服务器,只要有一个成功即返回,用于实时性较高的读操作,但需要浪费更多的服务资源,可通过forks=“2”来设置最大并行数量。
6)、Broadcast Cluster
广播调用所有提供者,逐个调用,任意一台报错则认为这次调用是失败的,适用于类似于同步的效果,例如通知所有提供者更新缓存或日志等本地资源信息。
*配置方式(二选其一即可)
服务消费者
1 @Reference(cluster = "failsafe") 2 private UserService userService;
服务提供者
1 @Component //org.springframework.stereotype.Component 2 @Service(cluster = "failsafe") //com.alibaba.dubbo.config.annotation.Service 3 public class UserServiceImpl implements UserService { 4 ... 5 }
作者:奇
出处:https://www.cnblogs.com/fanqisoft/p/10362946.html
版权:本作品采用「本文版权归作者和博客园共有,欢迎转载,但必须给出原文链接,并保留此段声明,否则保留追究法律责任的权利。」许可协议进行许可。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 单线程的Redis速度为什么快?
· SQL Server 2025 AI相关能力初探
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 展开说说关于C#中ORM框架的用法!