dbuuo包括协议,分别为:
达博协议
RMI协议
粗麻布协议
HTTP协议
网络服务协议
thirift协议
memcached的的协议
Redis的的协议
达博协议
达博协议采用单一长连接和NIO异步通讯,适合于小数据量大并发的服务调用,以及服务消费者机器数远大于服务提供者机器数的情况。
反之,达博协议不适合传送大数据量的服务,比如传文件,传视频等,除非请求量很低。
达博协议特性
使用基于 mina 1.1.7
和 hessian 3.2.1
的 tbremoting 交互。
- 连接个数:单连接
- 连接方式:长连接
- 传输协议:TCP
- 传输方式:NIO 异步传输
- 序列化:Hessian 二进制序列化
- 适用范围:传入传出参数数据包较小(建议小于100K),消费者比提供者个数多,单一消费者无法压满提供者,尽量不要用 dubbo 协议传输大文件或超大字符串。
- 适用场景:常规远程服务方法调用
约束
- 参数及返回值需实现
Serializable
接口 - 参数及返回值不能自定义实现
List
,Map
,Number
,Date
,Calendar
等接口,只能用 JDK 自带的实现,因为 hessian 会做特殊处理,自定义实现类中的属性值都会丢失。 - Hessian 序列化,只传成员属性值和值的类型,不传方法或静态变量,兼容情况
配置
配置协议:
<dubbo:protocol name="dubbo" port="20880" />
设置默认协议:
<dubbo:provider protocol="dubbo" />
设置服务协议
<dubbo:service protocol="dubbo" />
多端口
<dubbo:protocol id="dubbo1" name="dubbo" port="20880" />
<dubbo:protocol id="dubbo2" name="dubbo" port="20881" />
配置协议选项
<dubbo:protocol name=“dubbo” port=“9090” server=“netty” client=“netty” codec=“dubbo” serialization=“hessian2” charset=“UTF-8” threadpool=“fixed” threads=“100” queues=“0” iothreads=“9” buffer=“8192” accepts=“1000” payload=“8388608” />
多连接配置:
Dubbo协议默认提供一个服务者和一个消费者多的单一长连接,如果数据量大,可以使用多个连接
<dubbo:service connections="1"/>
<dubbo:reference connections="1"/>
rmi协议
rmi协议采用JDK标准的java.rmi.*实现,采用阻塞式短连接和JDK标准序列化方式。
注意:如果正在使用RMI提供服务给外部访问,同时