侧边栏壁纸
  • 累计撰写 781 篇文章
  • 累计创建 1 个标签
  • 累计收到 1 条评论
标签搜索

容错机制

Dettan
2021-04-10 / 0 评论 / 0 点赞 / 96 阅读 / 2,234 字
温馨提示:
本文最后更新于 2022-04-30,若内容或图片失效,请留言反馈。部分素材来自网络,若不小心影响到您的利益,请联系我们删除。

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="
0

评论区