记录使用dubbo遇到的问题
2016-06-29 17:28
851 查看
大伙使用过dubbo的同学都知道,dubbo远程调用服务原理是通过序列化、反序列化实现的,这里不多说了
问题描述:
有一次写dubbo接口,需要抛出自定义异常,该异常只有一个构造方法(只有一个参数,为自定义枚举类型),下面是构造方法详情
开始测试过程中一切正常,突然有一天出现如下异常:
开始很迷茫,最后终于发现,dubbo是采用Hessian(比jdk自带反序列化高效)进行反序列化的,该反序列化创建对象时,会取最少的构造方法创建对象,构造方法参数设置默认值,基本类型设置为相应基本类型的默认值,不是基本类型设置为null(就是这点,才导致我上面的构造方法出现空指针,进而导致该对象无法实例化)
最后通过新增无参构造方法解决了问题。
详细参考:http://hittyt.iteye.com/blog/1691772
该文章详细解释了问题所在
总结:需要通过dubbo服务传递的对象,保证有无参构造方法应该能避免这类问题。
但是一直有点疑问,既然这样的话,为啥刚开始测试并没有这个问题,后来突然才出现的,按理说这个问题一开始就应该出现才对,至今困惑中......
问题描述:
有一次写dubbo接口,需要抛出自定义异常,该异常只有一个构造方法(只有一个参数,为自定义枚举类型),下面是构造方法详情
public RefundOrderException(RefundOrderExceptionCode code) { super(code.name()); this.code = code; }
开始测试过程中一切正常,突然有一天出现如下异常:
Caused by: com.alibaba.com.caucho.hessian.io.HessianProtocolException: 'com.lianpay.lcpay. cb.exchangeorderserver.share.exception.RefundOrderException' could not be instantiated ...... ......
开始很迷茫,最后终于发现,dubbo是采用Hessian(比jdk自带反序列化高效)进行反序列化的,该反序列化创建对象时,会取最少的构造方法创建对象,构造方法参数设置默认值,基本类型设置为相应基本类型的默认值,不是基本类型设置为null(就是这点,才导致我上面的构造方法出现空指针,进而导致该对象无法实例化)
最后通过新增无参构造方法解决了问题。
详细参考:http://hittyt.iteye.com/blog/1691772
该文章详细解释了问题所在
总结:需要通过dubbo服务传递的对象,保证有无参构造方法应该能避免这类问题。
但是一直有点疑问,既然这样的话,为啥刚开始测试并没有这个问题,后来突然才出现的,按理说这个问题一开始就应该出现才对,至今困惑中......
相关文章推荐
- jackson、Gson反序列化 泛型
- c#数据的序列化和反序列化(推荐版)
- hessian 在PHP中的使用介绍
- .net实现序列化与反序列化实例解析
- C#实现的json序列化和反序列化代码实例
- Json序列化和反序列化方法解析
- 解析PHP多种序列化与反序列化的方法
- 深入理解Java对象的序列化与反序列化的应用
- C#反序列化到类的实现方法
- .Net中的序列化和反序列化详解
- Jil,高效的json序列化和反序列化库
- 详解PHP序列化反序列化的方法
- 详解Java中对象序列化与反序列化
- 理解Java的序列化与反序列化
- 浅析JSON序列化与反序列化
- php json与xml序列化/反序列化
- Dubbo-admin 不支持JDK8 解决办法
- 对外提供dubbo服务的最佳实践
- 搭建分布式架构2--CentOs下安装Tomcat7(环境准备)
- 搭建分布式架构4--ZooKeeper注册中心安装