为什么产生
我们来看看dubbo的源码进行分析,如果Dubbo的 provider端 抛出异常(Throwable),则会被 provider端 的ExceptionFilter拦截到,执行以下invoke方法,里面有个实现Listener类,重写了onResponse。

我们来分析一些代码:
if (appResponse.hasException() && GenericService.class != invoker.getInterface())
上面代码的含义就是 如果有异常并且未实现GenericService接口,进入后续判断逻辑,否则直接返回结果。

上面代码的含义就是 不是RuntimeException类型的异常,并且是受检异常(继承Exception),直接抛出。

上面代码的含义就是 在方法签名上有声明,直接抛出。

上面代码的含义就是 如果异常类和接口类在同一个jar包中,直接抛出。

上面代码的含义就是 以java.或javax.开头的异常直接抛出。

上面代码的含义就是dubbo自身的异常,直接抛出。

不满足上述条件,会做toString处理并被封装成RuntimeException抛出。
现在我们知道了 **为什么我们自定义的异常,没有正确的抛出,**这个是因为上面的几个条件,我们都没有满足,所以最后dubbo把它封装成了RuntimeException。
如何解决
解决方法就针对上面的几个条件进行,有几种方案,我们一一看一下:
1、将该异常的包名以java.或者javax.开头
这个方案不现实,也不符合规范,所以不采用
2、业务异常继承Exception,变为checked异常
自定义的业务异常本身属于RuntimeException,所以也不采用
3、异常类和接口类在同一jar包里
较大的项目一般都会有一些common包,定义好异常类型,使用二方包的方式引用,所以也不适用
4、provider的api明确写明throws XxxException
作为生产服务端,不应显式抛出异常给客户的进行处理,所以也不适用
最终方案
以上方案都不合适,我们这里介绍个最终的方案,即采用dubbo的filter重写,dubbo的异常处理。
1、将dubbo源码中ExceptionFilter复制到我们的项目改名为DubboExceptionFilter
修改一些代码

2、在此处加上一段代码来过滤我们项目中的异常,以免被dubbo重新封装
3、在resources目录下添加纯文本文件META-INF/dubbo/com.alibaba.dubbo.rpc.Filter并添加内容

dubboExceptionFilter=com.rainbow.goods.server.filter.
DubboExceptionFilter
4、修改dubbo 的配置文件,将DubboExceptionFilter加载进去并且去掉自身的ExceptionFilter
<dubbo:providerfilter="dubboExceptionFilter,-exception"/>
上面exception就是dubbo默认的处理异常的filter,前面-号就代表去除
我们修改后,再运行:
最后
以上分享的全部分布式技术专题+面试解析+相关的手写和学习的笔记pdf,高清完整版戳这里免费领取
还有更多Java笔记分享如下:
题+面试解析+相关的手写和学习的笔记pdf,高清完整版戳这里免费领取
还有更多Java笔记分享如下:

本文分析了Dubbo源码中处理异常的逻辑,解释了为何自定义异常会被封装成RuntimeException。探讨了几种解决方案,包括改变异常包名、修改异常类型、异常类与接口在同一jar包、明确声明throws,但这些方案并不适用。最终提出通过自定义DubboExceptionFilter并修改配置来过滤和处理项目中的特定异常。
6898

被折叠的 条评论
为什么被折叠?



