Dubbo服务集群

Posted 小不点啊

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Dubbo服务集群相关的知识,希望对你有一定的参考价值。

一、什么叫Dubbo服务集群

    指把同一个服务部署到多台机器,然后通过Dubbo服务集群的容错配置实现一台机器的服务挂掉之后自动切换到另外的一台机器

二、Dubbo服务集群容错配置——集群容错模式

属性:cluster

类型:string

是否必填:可选

缺省值:failover

作用:性能调优

集群方式:可选:failover/failfast/failsafe/failback/forking

兼容性:2.0.5以上版本

1、Failover Cluster(dubbo缺省配置)

失败自动切换,当出现失败,重试其它服务器(缺省)。通常用于读操作,但重试会带来更长延迟可通过retries="2"来设置重试次数(不含第一次)

1.1 可以在服务提供方配置,不配置时也是默认的如下配置

<dubbo:service cluster="failover" retries="2" />

1.2  可以在服务消费方配置,不配置时也是默认的如下配置

<dubbo:reference cluster="failover" retries="2" />

1.3 可以在消费方指定调用某个方法失败时的重试调用次数

<dubbo:reference>
<dubbo:method name="findFoo" retries="2" />
</dubbo:reference>

2、Failfast Cluster

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

2.1 可以在服务提供方配置

<dubbo:service cluster="failfast"  />

2.2  可以在服务消费方配置

<dubbo:reference cluster="failfast />

3、Failsafe Cluster

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

3.1 可以在服务提供方配置

<dubbo:service cluster=""failsafe""  />

3.2  可以在服务消费方配置

<dubbo:reference cluster=""failsafe"" />

4、Failback Cluster

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

4.1 可以在服务提供方配置

<dubbo:service cluster="failback" />

4.2  可以在服务消费方配置

<dubbo:reference cluster="failback" />

5、Forking Cluster

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

5.1 可以在服务提供方配置

<dubbo:service cluster="forking" />

5.2  可以在服务消费方配置

<dubbo:reference cluster="forking" />

三、集群容错配置的选择

一般情况下failover(读操作)和failfast(写操作)就可以满足需求;failover集群容错的retries的属性值改为"0"时等价于failfast






以上是关于Dubbo服务集群的主要内容,如果未能解决你的问题,请参考以下文章

Dubbo 系列(07-5)集群容错 - Mock

13.实战交付一套dubbo微服务到k8s集群之交付dubbo服务的消费者集群到K8S

Dubbo源码解析-高可用集群

Dubbo负载均衡与集群容错

妹妹问我:Dubbo集群容错负载均衡

妹妹问我:Dubbo集群容错负载均衡