Dubbo集群容错模式之Failsafe实现 原

注: Dubbo版本是2.6.2

                                               图1 Dubbo的FailsafeClusterInvoker类继承图

1.Failsafe的含义

    Failsafe可以理解为出现异常时,直接忽略。可以用在类似写日志之类的,允许一定量信息丢失的地方。

2.Failsafe的实现

    核心代码在FailsafeClusterInvoker的doInvoke(Invocation,List<Invoker<T>>,LoadBalance)中,源码如下。

@Override
public Result doInvoke(Invocation invocation, List<Invoker<T>> invokers, LoadBalance loadbalance) throws RpcException {
    try {
        checkInvokers(invokers, invocation);
        Invoker<T> invoker = select(loadbalance, invocation, invokers, null);
        return invoker.invoke(invocation);
    } catch (Throwable e) {
        logger.error("Failsafe ignore exception: " + e.getMessage(), e);
        return new RpcResult(); // ignore
    }
}
  • 首先根据loadbalance从服务提供者列表中选取一个。
  • 之后调用服务提供者的服务,如果调用成功,则直接返回结果;如果调用失败,则用error级别的日志记录exception,但是不抛出异常,之后返回一个默认值。

    比较好理解,重点在于不抛出底层的异常。

(adsbygoogle = window.adsbygoogle || []).push({});

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

扫码关注云+社区

领取腾讯云代金券