Dubbo剖析-集群容错

一、前言

在进行系统设计时候,不仅要考虑正常逻辑该如何走,还要考虑异常逻辑。dubbo中当服务消费方调用服务提供方的服务出现错误时候,提供了多种容错方案,缺省为 failover 重试。

二、Dubbo集群容错模式

  • Failover Cluster 重试。当服务消费方调用服务提供者失败后自动切换,重试其它服务提供者。这通常用于读操作或者具有幂等的写操作,需要注意的是重试会带来更长延迟。可通过 retries="2" 来设置重试次数(不含第一次)。 <dubbo:reference retries="2" />
  • Failfast Cluster 快速失败。当服务消费方调用服务提供者失败,失败立即报错。通常用于非幂等性的写操作。
  • Failsafe Cluster 失败安全。出现异常时,直接忽略。通常用于写入审计日志等操作。
  • Failback Cluster 失败自动恢复。后台记录失败请求,并按照一定的策略后期在进行重试。通常用于消息通知操作。
  • Forking Cluster 并行调用多个服务提供者的服务,只要一个成功即返回。通常用于实时性要求较高的读操作,但需要浪费更多服务资源。可通过 forks="2" 来设置最大并行数。
  • Broadcast Cluster 广播调用所有服务提供者,逐个调用,任意一台报错则报错 。通常用于通知所有提供者更新缓存或日志等本地资源信息

三、原理

3.1何时加载集群容错扩展实现类

image.png

3.2 FailoverClusterInvoker原理

image.png

四、总结

dubbo本身提供了丰富的集群容错模式,如果您有定制化需求,可以根据dubbo提供的扩展接口进行定制。

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏一个会写诗的程序员的博客

[idea]Error:java: invalid source release: 1.8

回归正题,出现这个问题的状况是我的电脑本机装的默认jdk版本是1.8.0_71,然后我平常开发用的jdk版本是免安装的1.7,只配置了环境变量,平常用eclip...

992
来自专栏数据派THU

收藏 | Linux常用156个命令汇总!

来源:机器学习算法与Python学习 本文为大家带来Linux系统中156个常用的命令。 linux命令是对Linux系统进行管理的命令。对于Linux系统来说...

50912
来自专栏一“技”之长

Git命令集十六——推送命令 原

471
来自专栏猿天地

Spring Cloud Sleuth Zipkin 展示追踪数据

上篇文章我们介绍了Spring Cloud Sleuth 链路追踪, 可以在输出的log中增加唯一请求的标识以及spanid, 然后可以采用ELK来对数据做集中...

3229
来自专栏影子

idea/eclipse下Maven工程集成web服务(tomcat、jetty)

转载请注明出处:http://www.cnblogs.com/funnyzpc/p/8093554.html

1222
来自专栏http://www.cnblogs.com

linux进程

1.查进程 ps命令查找与进程相关的PID号: ps a 显示现行终端机下的所有程序,包括其他用户的程序。 ps -A 显示所有程序。 ps c 列出程序时,显...

40510
来自专栏Dato

Maven的作用是什么

现在我们开发的项目基本上都是maven项目,maven项目也是一个项目,类似于javaProject,javaWebProject,就是多了些功能。 那就说说究...

35411
来自专栏影子

idea/eclipse下Maven工程集成web服务(tomcat、jetty)

1352
来自专栏机器学习算法与Python学习

手册 | Linux 运维人员最常用 150 个命令汇总

关键字全网搜索最新排名 【机器学习算法】:排名第一 【机器学习】:排名第一 【Python】:排名第三 【算法】:排名第四 本周六送5本《TensorFlow实...

3066
来自专栏Brian

Install Django Nginx uWSGI

概述 最近项目需要安装和配置多站点环境,所以把多站点开发环境配置和安装记录下来,帮助其他人少走坑。 安装Python 2.7.x 首先安装一些开发环境基本的包和...

3909

扫码关注云+社区

领取腾讯云代金券