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

作者:自东向西 时间:2023-11-24 14:25:13 

问题

开发过程中,发现服务提供者抛出了自定义的BusinessException,到了消费者这边,却变成了RuntimeException。

客户端这边有BusinessException这个类,提供者抛出的也是这个类的异常,为什么会被转成RpcException呢?

代码分析

看ExceptionFilter的代码:

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

重点就在圈起来的3个地方:

1、有异常,而且接口不能是GenericService才需要判断是否需要转换成RuntimeException,不然直接返回result。

2、如果是受检异常,则不转换,直接返回。

3、如果不是受检异常,则需要判断该异常是否在方法上声明抛出,如果有声明就不转换,直接返回。

如果不是上面的这三种情况,就会去到兜底逻辑:

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

兜底判断也是有三点:

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自己的异常类,消费者必然也有

最后

来源:https://blog.csdn.net/zidongxiangxi/article/details/108098173

标签:dubbo,异常,RuntimeException,ExceptionFilter
0
投稿

猜你喜欢

  • Java与Oracle实现事务(JDBC事务)实例详解

    2023-02-12 12:47:22
  • Android实现绘制折线图APP代码

    2022-12-10 07:50:02
  • C#实现斐波那契数列的几种方法整理

    2023-09-02 05:05:58
  • java json 省市级联实例代码

    2021-11-13 18:50:35
  • Java命名规则详细总结

    2023-11-14 12:20:55
  • springboot 整合 sa-token简介及入门教程

    2023-03-24 01:10:45
  • 深入理解SpringMVC中央调度器DispatcherServlet

    2023-03-11 08:54:48
  • 基于java构造方法Vector查找元素源码分析

    2023-11-29 04:33:30
  • Unity实现聊天室功能

    2023-12-20 19:53:34
  • C#单线程和多线程的端口扫描器应用比较详解

    2023-08-07 21:01:45
  • java设计模式之外观模式学习笔记

    2022-07-02 18:48:06
  • SpringBoot打War包上传到阿里云的LINUX服务器的操作方法

    2021-09-26 22:27:01
  • java struts2学习笔记之线程安全

    2022-08-07 00:13:07
  • c# WPF中的TreeView使用详解

    2021-05-24 15:17:58
  • 详解C#中的属性和属性的使用

    2023-12-03 09:51:39
  • Java解决No enclosing instance of type PrintListFromTailToHead is accessible问题的两种方案

    2022-10-30 00:31:51
  • maven profile动态选择配置文件详解

    2023-11-05 22:05:20
  • c#实现简单控制台udp异步通信程序示例

    2022-06-13 18:54:38
  • SpringMVC HttpMessageConverter消息转换器

    2023-01-13 04:57:45
  • C#值类型、引用类型中的Equals和==的区别浅析

    2022-09-05 23:04:24
  • asp之家 软件编程 m.aspxhome.com