dubbo是一种基于RPC实现的高性能分布式服务框架。除了默认dubbo协议外,还支持多种其他协议

dubbo协议

Dubbo缺省协议采用单一长连接和NIO异步通讯,适合于小数据量大并发的服务调用,以及服务消费者机器数远大于服务提供者机器数的情况。
反之,Dubbo 缺省协议不适合传送大数据量的服务,比如传文件,传视频等,除非请求量很低。




Transporter: mina, netty, grizzy

Serialization: dubbo, hessian2, java, json

Dispatcher: all, direct, message, execution, connection

ThreadPool: fixed, cached

<strong>特性</strong>
缺省协议,使用基于 mina 1.1.7 和 hessian3.2.1的 tbremoting 交互。
  ● 连接个数:单连接
  ● 连接方式:长连接
  ● 传输协议:TCP
  ● 传输方式:NIO 异步传输
  ● 序列化:Hessian 二进制序列化
  ● 适用范围:传入传出参数数据包较小(建议小于100K),消费者比提供者个数多,单一消费者无法压满提供者,尽量不要用 dubbo 协议传输大文件或超大字符串。
  ● 适用场景:常规远程服务方法调用

<strong>约束</strong>
  ● 参数及返回值需实现 Serializable 接口
  ● 参数及返回值不能自定义实现 List, Map, Number, Date, Calendar 等接口,只能用 JDK 自带的实现,因为 hessian 会做特殊处理,自定义实现类中的属性值都会丢失。
  ● Hessian 序列化,只传成员属性值和值的类型,不传方法或静态变量,兼容情况

RMI协议

RMI 协议采用 JDK 标准的 java.rmi.* 实现,采用阻塞式短连接和 JDK 标准序列化方式。
注意:如果正在使用 RMI 提供服务给外部访问,同时应用里依赖了老的 common-collections 包的情况下,存在反序列化安全风险。

<strong>特性</strong>
  ● 连接个数:多连接
  ● 连接方式:短连接
  ● 传输协议:TCP
  ● 传输方式:同步传输
  ● 序列化:Java 标准二进制序列化
  ● 适用范围:传入传出参数数据包大小混合,消费者与提供者个数差不多,可传文件。
  ● 适用场景:常规远程服务方法调用,与原生RMI服务互操作
<strong>约束</strong>
  ● 参数及返回值需实现 Serializable 接口
  ● dubbo 配置中的超时时间对 RMI 无效,需使用 java 启动参数设置:-Dsun.rmi.transport.tcp.responseTimeout=3000

Hession协议

Hessian 协议用于集成 Hessian 的服务,Hessian 底层采用 Http 通讯,采用 Servlet 暴露服务,Dubbo 缺省内嵌 Jetty 作为服务器实现。
Dubbo 的 Hessian 协议可以和原生 Hessian 服务互操作,即:
  ● 提供者用 Dubbo 的 Hessian 协议暴露服务,消费者直接用标准 Hessian 接口调用
  ● 或者提供方用标准 Hessian 暴露服务,消费方用 Dubbo 的 Hessian 协议调用。
<strong>特性</strong>
  ● 连接个数:多连接
  ● 连接方式:短连接
  ● 传输协议:HTTP
  ● 传输方式:同步传输
  ● 序列化:Hessian二进制序列化
  ● 适用范围:传入传出参数数据包较大,提供者比消费者个数多,提供者压力较大,可传文件。
  ● 适用场景:页面传输,文件传输,或与原生hessian服务互操作

<strong>约束
</strong>  ● 参数及返回值需实现 Serializable 接口
  ● 参数及返回值不能自定义实现 List, Map, Number, Date, Calendar 等接口,只能用 JDK 自带的实现,因为 hessian 会做特殊处理,自定义实现类中的属性值都会丢失。
<dependency><!--添加依赖 -->
    <groupId>com.caucho</groupId>
    <artifactId>hessian</artifactId>
    <version>4.0.7</version>
</dependency>

http协议

基于 HTTP 表单的远程调用协议,采用 Spring 的 HttpInvoker 实现

<strong>特性
</strong>  ● 连接个数:多连接
  ● 连接方式:短连接
  ● 传输协议:HTTP
  ● 传输方式:同步传输
  ● 序列化:表单序列化
  ● 适用范围:传入传出参数数据包大小混合,提供者比消费者个数多,可用浏览器查看,可用表单或URL传入参数,暂不支持传文件。
  ● 适用场景:需同时给应用程序和浏览器 JS 使用的服务。

<strong>约束</strong>
  ● 参数及返回值需符合 Bean 规范

Webservice协议

基于 WebService 的远程调用协议,基于 Apache CXF的 frontend-simple 和 transports-http 实现。
可以和原生 WebService 服务互操作,即:
● 提供者用 Dubbo 的 WebService 协议暴露服务,消费者直接用标准 WebService 接口调用,
● 或者提供方用标准 WebService 暴露服务,消费方用 Dubbo 的 WebService 协议调用。

<strong>特性</strong>
  ● 连接个数:多连接
  ● 连接方式:短连接
  ● 传输协议:HTTP
  ● 传输方式:同步传输
  ● 序列化:SOAP 文本序列化
  ● 适用场景:系统集成,跨语言调用
<strong>约束</strong>
  ● 参数及返回值需实现 Serializable 接口
  ● 参数尽量使用基本类型和 POJO
<dependency> <!--添加依赖 -->
    <groupId>org.apache.cxf</groupId>
    <artifactId>cxf-rt-frontend-simple</artifactId>
    <version>2.6.1</version>
</dependency>
<dependency>
    <groupId>org.apache.cxf</groupId>
    <artifactId>cxf-rt-transports-http</artifactId>
    <version>2.6.1</version>
</dependency>

Thrift协议

当前 dubbo 支持的thrift 协议是对 thrift 原生协议的扩展,在原生协议的基础上添加了一些额外的头信息,比如 service name,magic number 等。
使用 dubbo thrift 协议同样需要使用 thrift 的 idl compiler 编译生成相应的 java 代码,后续版本中会在这方面做一些增强。Thrift 是 Facebook 捐给 Apache 的一个 RPC 框架。

<dependency>   <!-- 添加依赖 -->
    <groupId>org.apache.thrift</groupId>
    <artifactId>libthrift</artifactId>
    <version>0.8.0</version>
</dependency>

Memcached, Redis协议

基于Memcached实现的RPC协议,Memcached是一个高效的kv缓存服务器
基于Redis实现的RPC协议


dubbo各个协议的性能测试报告如下:http://dubbo.apache.org/zh-cn/docs/user/perf-test.html