1) Failover Cluster 模式失败自动切换,当出现失败,重试其它服务器。 (默认)
2) Failfast Cluster快速失败,只发起一次调用,失败立即报错。 通常用于非幂等性的写操作,比如新增记录。
3) Failsafe Cluster失败安全,出现异常时,直接忽略。 通常用于写入审计日志等操作。
4) Failback Cluster失败自动恢复,后台记录失败请求,定时重发。 通常用于消息通知操作。
5) Forking Cluster并行调用多个服务器,只要一个成功即返回。 通常用于实时性要求较高的读操作,但需要浪费更多服务资源。可通过 forks=” 2”来设置最大并行数。
6) Broadcast Cluster广播调用所有提供者,逐个调用,任意一台报错则报错。 (2.1.0 开始支持) 通常用于通知所有提供者更新缓存或日志等本地资源信息。
总结: 在实际应用中查询语句容错策略建议使用默认 Failover Cluster ,而增删改建议使用 Failfast Cluster 或者 使用 Failover Cluster(retries=” 0”) 策略 防止出现数据 重复添加等等其它问题!建议在设计接口时候把查询接口方法单独做一个接口提供查询。
. dubbo 服务集群配置(集群容错模式)
在集群调用失败时, Dubbo 提供了多种容错方案,缺省为 failover 重试。可以自行扩展集群容错策略
l Failover Cluster(默认)
失败自动切换,当出现失败,重试其它服务器。 (缺省)通常用于读操作,
但重试会带来更长延迟。可通过 retries="2"来设置重试次数(不含第一次)。
[AppleScript] 纯文本查看 复制代码
? 1 2 3 4<dubbo:service retries="2" cluster="failover"/>
或:
<dubbo:reference retries="2" cluster="failover"/>
cluster="failover"可以不用写,因为默认就是 failoverl Failfast Cluster
快速失败,只发起一次调用,失败立即报错。通常用于非幂等性的写操作,
比如新增记录。
[AppleScript] 纯文本查看 复制代码
? 1 2 3 4dubbo:service cluster="failfast" />
或:
<dubbo:reference cluster="failfast" />
cluster="failfast"和 把 cluster="failover"、 retries="0"是一样的效果,retries="0"就是不重试l Failsafe Cluster
失败安全,出现异常时,直接忽略。通常用于写入审计日志等操作。
[AppleScript] 纯文本查看 复制代码
?
1 2 3<dubbo:service cluster="failsafe" />
或:
<dubbo:reference cluster="failsafe" />l Failback Cluster
失败自动恢复,后台记录失败请求,定时重发。通常用于消息通知操作。
[AppleScript] 纯文本查看 复制代码
? 1 2 3<dubbo:service cluster="failback" />
或:
<dubbo:reference cluster="failback" />l Forking Cluster
并行调用多个服务器,只要一个成功即返回。通常用于实时性要求较高的读
操作,但需要浪费更多服务资源。可通过 forks="2"来设置最大并行数。
[AppleScript] 纯文本查看 复制代码
? 1 2 3<dubbo:service cluster=“forking" forks="2"/>
或:
<dubbo:reference cluster=“forking" forks="2"/>l 配置
[AppleScript] 纯文本查看 复制代码
? 1 2 3 4 5 6服务端服务级别
<dubbo:service interface="..." loadbalance="roundrobin" />
客户端服务级别
<dubbo:reference interface="..." loadbalance="roundrobin" />
服务端方法级别 <dubbo:service interface="..."> <dubbo:method name="..." loadbalance
客户端方法级别 <dubbo:reference interface="..."> <dubbo:method name="..." loadbalance="
评论区