注: Dubbo版本是2.6.2
图1 Dubbo的FailsafeClusterInvoker类继承图
1.Failsafe的含义
Failsafe可以理解为出现异常时,直接忽略。可以用在类似写日志之类的,允许一定量信息丢失的地方。
2.Failsafe的实现
核心代码在FailsafeClusterInvoker的doInvoke(Invocation,List<Invoker
@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,但是不抛出异常,之后返回一个默认值。
比较好理解,重点在于不抛出底层的异常。