前言

我们在开发应用系统时,不可避免的要使用到我们自己定义的异常,所以我们一般通常会用到自定义的业务异常类BusinessException,这个异常会继承extends RuntimeException,当发生业务限制的时候,会throw出来。

问题

在SpringMVC项目中,我们可以采用@ControllerAdvice注解,拦截我们的业务异常类,然后做一些处理。

网上有很多SpringMVC项目如何统一处理异常。老顾这里就不做介绍

但是现在项目都是微服务化的,在使用dubbo构建项目时,会发现provider抛出自定义业务异常,在custom端并不能正确的捕获。即便我们在provider和custom都有导入相同jar包下面的BusinessException异常,并且抛出这个异常。下面是出错情况

老顾采用dubbo版本为2.7.3版本,跟老版本有点区别,但区别不大

provicer生产者代码

其中的DataNotFoundException继承了BusinessException

DataNotFoundException 的编码以及错误信息: PUBLIC_DATA_NOT_FOUND(1001,"数据没有找到") 

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

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

我们修改后,再运行:

抛出的是我们自定义的异常了,在看看消费端的异常处理最终显示

确实是我们定义的DataNotFoundException业务异常的编码和信息。

总结

上面的是基于重写dubbo的filter处理了异常,网上有一些别的方案,老顾认为不是太合理,不够灵活,利用修改dubbo源码的方式解决更能彻底解决;希望能够给小伙伴带来帮助。谢谢!!!

view [bootstrap-4] not found如何解决_Dubbo如何处理业务异常,这个一定要知道哦相关推荐

  1. 理解和解决Java并发修改异常ConcurrentModificationException(转载)

    原文地址:https://www.jianshu.com/p/f3f6b12330c1 理解和解决Java并发修改异常ConcurrentModificationException 不知读者在Java ...

  2. 解决C#导出excel异常来自 HRESULT:0x800A03EC的方法 .

    解决C#导出excel异常来自 HRESULT:0x800A03EC的方法 . 参考文章: (1)解决C#导出excel异常来自 HRESULT:0x800A03EC的方法 . (2)https:// ...

  3. android 解决java.nio.BufferOverflowException 异常

    昨天,测试程序时,发现程序了java.nio.BufferOverflowException 异常,后来,在网上搜索了资料,终于解决了问题.这里记录一下. ByteBuffer params = By ...

  4. vs 启动调用的目标发生异常_如何解决不可测、异常场景的问题?

    阿里QA导读:在软件研发过程中,发布前跨多个系统的联调测试是不可或缺的一环,而在联调过程中,经常会遇到一些比较棘手的困难,阻塞整个联调进程.其中比较典型的有:第三方的研发节奏不一致,导致无法联调:下游 ...

  5. @Controller与@RestController的区别以及ircular view path [ad]: would dispatch back to the current handler异常

    QUESTION:@Controller与@RestController的区别以及ircular view path [ad]: would dispatch back to the current ...

  6. 【干货】借助用户画像解决电商业务问题.pdf(附下载链接)

    今天给大家带来姚凯飞先生所做的分享<借助用户画像解决电商业务问题.pdf>.关注用户画像及电商的伙伴们别错过了! 另外,我们也搭建了电商行业交流社群,电商行业的伙伴们可以扫码进群交流: 本 ...

  7. Spring boot 解决 hibernate no session异常

    Spring boot 解决 hibernate no session异常 参考文章: (1)Spring boot 解决 hibernate no session异常 (2)https://www. ...

  8. 【Bug】解决 java.sql.SQLSyntaxErrorException 异常

    [Bug]解决 java.sql.SQLSyntaxErrorException 异常 参考文章: (1)[Bug]解决 java.sql.SQLSyntaxErrorException 异常 (2) ...

  9. 让Qt程序适配高分辨率屏幕,解决软件界面错乱异常

    让Qt程序适配高分辨率屏幕,解决软件界面错乱异常 一.问题 二.原因 三.解决方案 1.更改显示器分辨率或者不使用缩放 2.使用"高DIP缩放替代" 3.修改软件,使之自动适配 a ...

最新文章

  1. 《OpenCV3编程入门》学习笔记5 Core组件进阶(四)图像对比度、亮度值调整
  2. Python 计算欧氏距离
  3. debain安装lyx2.2.2,以及报错整理:
  4. Oracle分页查询语句
  5. Verilg 2001相对于Verilog 1995的改进(Z) (内含 乘方 运算符** )
  6. mysql dump 10.13_mysqldump版本引起的问题
  7. 测试开发:聊一聊自动化测试框架,值得收藏!
  8. HDOJ 1394 Minimum Inversion Number
  9. BIOS、BootLoader、uboot对比
  10. v50进9008救砖
  11. 计算机技术应用于测量,在测量绘图中计算机技术的应用分析
  12. iPad入手必备手册——iPad Mini 使用手册(适用于iOS 6软件 )
  13. 腾讯多媒体实验室:基于三维卷积神经网络的全参考视频质量评估算法
  14. ubuntu20编译Gmssl时,“version OPENSSL_1_1_0d not defined”问题的较好解决办法
  15. jQuery事件注册、jQuery事件对象、事件处理
  16. EA常见画图(类图、包图、构件图、状态图、顺序图、活动图)
  17. WinDebug 调试工具-0
  18. 朴素贝叶斯+语言模型
  19. SDRconsole3.0 适用hackrf等软件无线电
  20. 【文化课每周学习记录】高三上暑假

热门文章

  1. 689 Maximum Sum of 3 Non-Overlapping Subarrays
  2. [Leetcode][第216题][JAVA][数组之和3][回溯]
  3. [Leetcode][第309题][JAVA][最佳买卖股票时机含冷冻期][动态规划][压缩空间]
  4. GPLT2017题目
  5. 印象笔记mac版 同步问题_印象笔记表示 今年将大幅提升产品体验
  6. mysql leave的作用_MySQL数据库中DELIMITER的作用
  7. tx2无法识别网络_Jetson TX2开篇--网络配置
  8. input ios问题 小程序_小程序可以解决哪些问题??
  9. 数据产品经理修炼手册pdf_【尼读书】数据产品经理修炼手册(附思维导图)
  10. 人工神经网络_制作属于自己的人工神经网络