dubbo将异常转换成RuntimeException原因分析——ExceptionFilter

问题

开发过程中,发现服务提供者抛出了自定义的BusinessException,到了消费者这边,却变成了RuntimeException。
客户端这边有BusinessException这个类,提供者抛出的也是这个类的异常,为什么会被转成RpcException呢?

代码分析

看ExceptionFilter的代码:
在这里插入图片描述

重点就在圈起来的3个地方:
1、有异常,而且接口不能是GenericService才需要判断是否需要转换成RuntimeException,不然直接返回result。
2、如果是受检异常,则不转换,直接返回。
3、如果不是受检异常,则需要判断该异常是否在方法上声明抛出,如果有声明就不转换,直接返回。


如果不是上面的这三种情况,就会去到兜底逻辑:
在这里插入图片描述

兜底判断也是有三点:
1、判断接口和异常是否在一个jar包中,如果是在一个jar包,不需要转换成RuntimeException。
2、如果异常是java异常,不需要处理。
3、异常类型是RpcException,不需要处理。

如果这三者都不满足,就会到达代码:
return new RpcResult(new RuntimeException(StringUtils.toString(exception)));
异常会被转成字符串,作为RuntimeException的构造函数入参。

结论

由于BusinessException是在一个通用工具包中,和接口不在一个jar包中,BusinessException也不是受检异常,所以不满足不转换的条件。
要让提供者抛出的异常不被转成RuntimeException,可以在定义方法的时候,声明 throws BusinessException。

思考

为什么dubbo要这样判断是否需要转成RuntimeException呢?
个人觉得,依据是消费者能否反序列化成对应的异常类,消费端有抛出的这个异常类,就能成功反序列化。
1、能抛出受检异常,那么在方法上必然声明了抛出该异常,客户端包里会有该异常类
2、同理,如果不是受检异常,但是在方法上声明了,客户端也会有
3、如果接口和异常类是在同一个jar吧,说明客户端包里有异常类
4、jdk自己的异常类,自然是存在的
5、RpcException是dubbo自己的异常类,消费者必然也有

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值