微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

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 }

 

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐