副本 dubbo如何处理业务异常,这个一定要知道哦!

consumer消费者代码

图片

运行,输入不存在的goodsID,我们期望我们自定义的异常类被我们拦截到,并做一些处理;但是provider生产端抛给消费者的异常竟然是RuntimeException,只是里面的message是我们的业务异常调用栈信息。如下图片

不是我们希望的抛给消费者端是DataNotFoundException异常。导致我们消费端没法针对不同的业务进行不同的处理。消费端做了SpringMVC的异常处理返回了图片

上面的code为1401,是系统异常编码,并不是DataNotFoundException编码

我们定义的DataNotFoundException的编码为:1001

为什么产生

我们来看看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:provider filter=“dubboExceptionFilter,-exception” />

上面exception就是dubbo默认的处理异常的filter,前面-号就代表去除

我们修改后,在运行

最后

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数初中级Android工程师,想要提升技能,往往是自己摸索成长,自己不成体系的自学效果低效漫长且无助

因此我收集整理了一份《2024年Android移动开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点!不论你是刚入门Android开发的新手,还是希望在技术上不断提升的资深开发者,这些资料都将为你打开新的学习之门

如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!
bs.csdn.net/topics/618165277)

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值