协议名称 | 描述 | 连接个数 | 连接方式 | 传输协议 | 传输方式 | 序列化 | 适用范围 | 适用场景 | 约束 |
dubbo:// | Dubbo 缺省协议采用单一长连接和 NIO 异步通讯,适合于小数据量大并发的服务调用,以及服务消费者机器数远大于服务提供者机器数的情况。 | 单连接 | 长连接 | TCP | IO 异步传输 | Hessian 二进制序列化 | 传入传出参数数据包较小(建议小于100K),消费者比提供者个数多,单一消费者无法压满提供者,尽量不要用 dubbo 协议传输大文件或超大字符串。 | 常规远程服务方法调用 | 参数及返回值需实现 Serializable 接口 参数及返回值不能自定义实现 List, Map, Number, Date, Calendar 等接口,只能用 JDK 自带的实现,因为 hessian 会做特殊处理,自定义实现类中的属性值都会丢失。 Hessian 序列化,只传成员属性值和值的类型,不传方法或静态变量,兼容情况 |
rmi:// | RMI 协议采用 JDK 标准的 java.rmi.* 实现,采用阻塞式短连接和 JDK 标准序列化方式。 | 多连接 | 短连接 | TCP | 同步传输 | Java 标准二进制序列化 | 传入传出参数数据包大小混合,消费者与提供者个数差不多,可传文件 | 常规远程服务方法调用,与原生RMI服务互操作 | 参数及返回值需实现 Serializable 接口 dubbo 配置中的超时时间对 RMI 无效,需使用 java 启动参数设置:-Dsun.rmi.transport.tcp.responseTimeout=3000 |
hessian:// | Hessian 协议用于集成 Hessian 的服务,Hessian 底层采用 Http 通讯,采用 Servlet 暴露服务,Dubbo 缺省内嵌 Jetty 作为服务器实现 | 多连接 | 短连接 | HTTP | 同步传输 | Hessian二进制序列化 | 传入传出参数数据包较大,提供者比消费者个数多,提供者压力较大,可传文件 | 页面传输,文件传输,或与原生hessian服务互操作 | 参数及返回值需实现 Serializable 接口 参数及返回值不能自定义实现 List, Map, Number, Date, Calendar 等接口,只能用 JDK 自带的实现,因为 hessian 会做特殊处理,自定义实现类中的属性值都会丢失。 Hessian 序列化,只传成员属性值和值的类型,不传方法或静态变量,兼容情况 |
http:// | 基于 HTTP 表单的远程调用协议,采用 Spring 的 HttpInvoker 实现 | 多连接 | 短连接 | HTTP | 同步传输 | 表单序列化 | 传入传出参数数据包大小混合,提供者比消费者个数多,可用浏览器查看,可用表单或URL传入参数,暂不支持传文件 | 需同时给应用程序和浏览器 JS 使用的服务 | 参数及返回值需符合 Bean 规范 |
webservice:// | 基于 WebService 的远程调用协议,基于 Apache CXF 的 frontend-simple 和 transports-http 实现 | 多连接 | 短连接 | HTTP | 同步传输 | SOAP 文本序列化 | 系统集成,跨语言调用 | ||
thrift:// | 当前 dubbo 支持 的 thrift 协议是对 thrift 原生协议的扩展,在原生协议的基础上添加了一些额外的头信息,比如 service name,magic number 等 | ||||||||
memcached:// | 基于 memcached 实现的 RPC 协议 | ||||||||
redis:// | 基于 Redis 实现的 RPC 协议 | ||||||||
rest:// | 基于标准的Java REST API——JAX-RS 2.0(Java API for RESTful Web Services的简写)实现的REST调用支持 |