搞定 Dubbo 系列(四):集群的容错机制

桃扇骨 2023-06-26 05:43 67阅读 0赞

一、集群容错(重试机制)

Dubbo的容错机制,又叫重试机制。在集群调用失败时,Dubbo 提供了多种容错方案,缺省为 Failover 重试。

watermark_type_ZmFuZ3poZW5naGVpdGk_shadow_10_text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3NoaXBmZWlfY3Nkbg_size_16_color_FFFFFF_t_70

说明:

  1. Invoker 是 Provider 的一个可调用 Service 的抽象,Invoker 封装了 Provider 地址及 Service 接口信息。
  2. Directory 代表多个 Invoker,可以把它看成 List ,但与 List 不同的是,它的值可能是动态变化的,比如注册中心推送变更。
  3. Cluster 将 Directory 中的多个 Invoker 伪装成一个 Invoker,对上层透明,伪装过程包含了容错逻辑,调用失败后,重试另一个。
  4. Router 负责从多个 Invoker 中按路由规则选出子集,比如读写分离,应用隔离等。
  5. LoadBalance 负责从多个 Invoker 中选出具体的一个用于本次调用,选的过程包含了负载均衡算法,调用失败后,需要重选。

二、5 种容错机制

dubbo提供了5种容错机制,如下,

1、failover cluster(默认)

失败自动切换,调用失败时,自动重试其他机器。通常用于读操作,但重试会带来更长延迟。可通过 retries=”2” 来设置重试次数(不含第一次)。

  1. <dubbo:service retries="2" /> #提供者
  2. <dubbo:reference retries="2" /> #消费者

2、Failfast Cluster

快速失败,只发起一次调用,失败立即报错。通常用于非幂等性的写操作,比如新增记录

3、Failsafe Cluster

失败安全,出现异常时,直接忽略。通常用于写入审计日志等操作

4、Failback Cluster

失败自动恢复,后台记录失败请求,定时重发。通常用于消息通知操作

5、Forking Cluster

并行调用多个服务器,只要一个成功即返回。通常用于实时性要求较高的读操作,但需要浪费更多服务资源。可通过 forks=”2” 来设置最大并行数。

三、集群模式配置

watermark_type_ZmFuZ3poZW5naGVpdGk_shadow_10_text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3NoaXBmZWlfY3Nkbg_size_16_color_FFFFFF_t_70 1

在服务提供者和消费者里面,可参考如下配置,

1、xml配置

  1. <dubbo:service cluster="failover" /> # 提供者
  2. <dubbo:reference cluster="failover" /> #消费者

2、注解配置

  1. @Service(interfaceClass = IBookService.class, loadbalance = "roundrobin", cluster = "failover", retries = 3, version = "1.0")
  2. @Reference(interfaceClass = IBookService.class, loadbalance = "random", cluster = "failover",retries = 3, version = "1.0")

发表评论

表情:
评论列表 (有 0 条评论,67人围观)

还没有评论,来说两句吧...

相关阅读

    相关 dubbo容错

    为了避免单点故障,现在的应用通常至少会部署在两台服务器上。对于一些负载比较高的服务,会部署更多的服务器。这样, 在同一环境下的服务提供者数量会大于1。对于服务消费者来说,同一环

    相关 谈谈dubbo容错

    从继承图可以看出有以下几种策略: Failover Cluster(失败转移) 当调用提供者的服务器发生错误时,再试下一个服务器。 用于读操作。重试有延时。设置重试次数

    相关 Dubbo容错

    Dubbo官网:[dubbo 2.7  集群容错][dubbo 2.7_] 集群容错指的是,当消费者调用提供者集群时发生异常的处理方案 一、Dubbo内置的容错策略

    相关 Dubbo-容错

    当一个项目(应用或服务)放在多台服务器上时,怎么实现高可用,这就是集群容错。 \------------------------------------------

    相关 Dubbo——容错

    Cluster层概述 在微服务环境中,为了保证服务的高可用,很少会有单点服务出现,服务通常都是以集群的形式出现的。然而,被调用的远程服务并不是每时每刻都保持良好状况,当某