zoukankan      html  css  js  c++  java
  • Dubbo服务容错

      当一个服务调用另一个远程服务出现错误时的外观

      Dubbo提供了多种容错方案,默认值为failover(重试)

      1)、Failover Cluster(默认)

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

      2)、Failfast Cluster

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

      3)、Failsafe Cluster

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

      4)、Failback Cluster

      失败自动重发,后台记录失败请求,定时重发,用于一些一定要成功的服务调用,例如消息通知等。

      5)、Forking Cluster

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

      6)、Broadcast Cluster

      广播调用所有提供者,逐个调用,任意一台报错则认为这次调用是失败的,适用于类似于同步的效果,例如通知所有提供者更新缓存或日志等本地资源信息。

    *配置方式(二选其一即可)

      服务消费者

    1     @Reference(cluster = "failsafe")
    2     private UserService userService;

      服务提供者

    1 @Component  //org.springframework.stereotype.Component
    2 @Service(cluster = "failsafe")    //com.alibaba.dubbo.config.annotation.Service
    3 public class UserServiceImpl implements UserService {
    4   ...  
    5 }
  • 相关阅读:
    android项目启动应用,卸载应用,分享
    android项目复杂的listview
    android项目获得手机里所有的应用程序
    android项目获取指定目录下可用空间
    android项目实现电话自动挂断的功能
    android项目浮窗的移动
    android项目双击或者多击的实现
    C#设计模式之工厂方法与简单工厂
    C#二分查找法与拉格朗日查找法
    C#快速排序算法
  • 原文地址:https://www.cnblogs.com/fanqisoft/p/10362946.html
Copyright © 2011-2022 走看看