关于Dubbo传输协议与上传文件的坑

关于Dubbo传输协议与上传文件的坑

1.Dubbo传输协议
  • Dubbo协议
  • Hessian协议
  • HTTP协议
  • RMI协议
  • WebService协议
  • Thrift协议
  • Memcached协议
  • Redis协议
2.主要说一下Dubbo协议和Hessian协议的适用情况

Dubbo协议采用单一长连接和NIO异步通讯,适合于小数据量大并发的服务调用,以及服务消费者机器数远大于服务提供者机器数的情况

Hessian协议用于集成Hessian的服务,Hessian底层采用Http通讯,采用Servlet暴露服务。适用场景:传入传出参数数据包较大,提供者比消费者个数多,提供者压力较大,可传文件。因此比较高效的做法是带上传下载文件的服务使用hessian协议,去普通的服务使用dubbo协议。

3.上传文件时遇到的坑

最近在做FastDFS图片服务器上传图片功能,遇到了如下的问题。

com.alibaba.com.caucho.hessian.io.HessianProtocolException: ‘org.springframework.web.multipart.commons.CommonsMultipartFile’ could not be instantiated

问题原因:通过Dubbo协议传输时,使用RPC协议传输,数据需要经过序列化和反序列化的过程,我们往往需要将传输对象进行序列化操作,而如果传输MultipartFile等File类型文件时,由于common-upload包装返回的是一个common的类,而这个类我们不可能去改源码序列化它,所以传输时会报出如下的错误提示。
在这里插入图片描述
在这里插入图片描述

4.解决方法

第一种解决方法,在Controller层里将MultipartFile file进行处理,将MultipartFile进行处理,改为byte[]数据传输到服务层。

return picUploadService.picUpload(uploadFile.getBytes(),pic_type);//通过getBytes方法传输byte[]类型数据

第二种解决方法,使用Hessian协议,进行如下修改

修改之前

	<dubbo:protocol name="dubbo" port="20880" />
    <!-- 声明需要暴露的服务接口 -->
    <dubbo:service interface="com.PicUploadService" ref="picUploadServiceImpl"/>

修改之后

<dubbo:protocol name="hessian" port="20880" />
    <!-- 声明需要暴露的服务接口 -->
    <dubbo:service protocol="hessian" interface="com.PicUploadService" ref="picUploadServiceImpl"/>
5.如何选择

可以详细了解一下两种协议的区别和使用的坑,根据自己业务情况选择。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值