关于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包装