Dubbo协议介绍

Dubbo协议介绍关于 Dubbo 使用的 demo 我在这就不多介绍了 因为很简单 网上资源也很多 在这里我简单介绍一下 Dubbo 的配置中使用到的最常用的协议 在介绍协议之前 首先要介绍一下 Dubbo 的线程模型事件处理线程说明如果事件处理的逻辑能迅速完成 并且不会发起新的 IO 请求 比如只是在内存中记个标识 则直接在 IO 线程上处理更快 因为减少了线程池调度 但如果事件处理逻辑较慢 或者需要

关于Dubbo使用的demo我在这就不多介绍了,因为很简单,网上资源也很多。在这里我简单介绍一下Dubbo的配置中使用到的最常用的协议。

在介绍协议之前,首先要介绍一下Dubbo的线程模型

Dubbo协议介绍


事件处理线程说明

如果事件处理的逻辑能迅速完成,并且不会发起新的IO请求,比如只是在内存中记个标识,则直接在IO线程上处理更快,因为减少了线程池调度。 但如果事件处理逻辑较慢,或者需要发起新的IO请求,比如需要查询数据库,则必须派发到线程池,否则IO线程阻塞,将导致不能接收其它请求。 如果用IO线程处理事件,又在事件处理过程中发起新的IO请求,比如在连接事件中发起登录请求,会报“可能引发死锁”异常,但不会真死锁。 

Dispatcher

all 所有消息都派发到线程池,包括请求,响应,连接事件,断开事件,心跳等。 direct 所有消息都不派发到线程池,全部在IO线程上直接执行。 message 只有请求响应消息派发到线程池,其它连接断开事件,心跳等消息,直接在IO线程上执行。 execution 只请求消息派发到线程池,不含响应,响应和其它连接断开事件,心跳等消息,直接在IO线程上执行。 connection 在IO线程上,将连接断开事件放入队列,有序逐个执行,其它消息派发到线程池。 

ThreadPool

fixed 固定大小线程池,启动时建立线程,不关闭,一直持有。(缺省) cached 缓存线程池,空闲一分钟自动删除,需要时重建。 limited 可伸缩线程池,但池中的线程数只会增长不会收缩。(为避免收缩时突然来了大流量引起的性能问题)。 

配置如下:

 
    

接下来,就介绍一下Dubbo的协议。

Dubbo支持的协议很多,包括:dubbo、rmi、hessian、http、webservice、thrift、memcached、redis等。

在这里只简单介绍一下dubbo协议,这个协议也是官方推荐的协议,也是我工作中使用到的协议。

Dubbo协议默认值:

Transporter:

mina, netty, grizzy 

Serialization:

dubbo, hessian2, java, json 

Dispatcher:

all, direct, message, execution, connection 

ThreadPool:

fixed, cached 

特点:

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

Dubbo缺省协议不适合传送大数据量的服务,比如传文件,传视频等,除非请求量很低。

格式:

 
    

设置默认协议:

 
    

设置service协议

 
    

多端口

 
    
    

其他:

 
    

Dubbo协议缺省每服务每提供者每消费者使用单一长连接,如果数据量较大,可以使用多个连接。

 
    
   
      表示该服务使用JVM共享长连接。(缺省) 
     
        表示该服务使用独立长连接。 
       
          表示该服务使用独立两条长连接。 
         
        
       
      
     
   

缺省协议,使用基于mina1.1.7+hessian3.2.1的tbremoting交互。

连接个数:单连接 连接方式:长连接 传输协议:TCP 传输方式:NIO异步传输 序列化:Hessian二进制序列化 适用范围:传入传出参数数据包较小(建议小于100K),消费者比提供者个数多,单一消费者无法压满提供者,尽量不要用dubbo协议传输大文件或超大字符串。 适用场景:常规远程服务方法调用 

为什么要消费者比提供者个数多:

因dubbo协议采用单一长连接, 假设网络为千兆网卡(1024Mbit=128MByte), 根据测试经验数据每条连接最多只能压满7MByte(不同的环境可能不一样,供参考), 理论上1个服务提供者需要20个服务消费者才能压满网卡。

为什么不能传大包:

因dubbo协议采用单一长连接, 如果每次请求的数据包大小为500KByte,假设网络为千兆网卡(1024Mbit=128MByte),每条连接最大7MByte(不同的环境可能不一样,供参考), 单个服务提供者的TPS(每秒处理事务数)最大为:128MByte / 500KByte = 262。 单个消费者调用单个服务提供者的TPS(每秒处理事务数)最大为:7MByte / 500KByte = 14。 如果能接受,可以考虑使用,否则网络将成为瓶颈。

为什么采用异步单一长连接:

因为服务的现状大都是服务提供者少,通常只有几台机器, 而服务的消费者多,可能整个网站都在访问该服务, 比如Morgan的提供者只有6台提供者,却有上百台消费者,每天有1.5亿次调用, 如果采用常规的hessian服务,服务提供者很容易就被压跨, 通过单一连接,保证单一消费者不会压死提供者, 长连接,减少连接握手验证等, 并使用异步IO,复用线程池,防止C10K问题。

约束

参数及返回值需实现Serializable接口 参数及返回值不能自定义实现List, Map, Number, Date, Calendar等接口,只能用JDK自带的实现,因为hessian会做特殊处理,自定义实现类中的属性值都会丢失。() Hessian序列化,只传成员属性值和值的类型,不传方法或静态变量,兼容情况:(由吴亚军提供) 
数据通讯 情况 结果
A->B 类A多一种 属性(或者说类B少一种 属性) 不抛异常,A多的那 个属性的值,B没有, 其他正常
A->B 枚举A多一种 枚举(或者说B少一种 枚举),A使用多 出来的枚举进行传输 抛异常
A->B 枚举A多一种 枚举(或者说B少一种 枚举),A不使用 多出来的枚举进行传输 不抛异常,B正常接 收数据
A->B A和B的属性 名相同,但类型不相同 抛异常
A->B serialId 不相同 正常传输

总结:会抛异常的情况:枚 举值一边多一种,一边少一种,正好使用了差别的那种,或者属性名相同,类型不同

接口增加方法,对客户端无影响,如果该方法不是客户端需要的,客户端不需要重新部署; 输入参数和结果集中增加属性,对客户端无影响,如果客户端并不需要新属性,不用重新 部署; 输入参数和结果集属性名变化,对客户端序列化无影响,但是如果客户端不重新部署,不管输入还是输出,属性名变化的属性值是获取不到的。 

总结:服务器端和客户端对领域对象并不需要完全一致,而是按照最大匹配原则。

更多内容,欢迎关注微信公众号:Java小笔记(ijavanote)

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/222387.html原文链接:https://javaforall.net

(0)
上一篇 2026年3月17日 下午3:53
下一篇 2026年3月17日 下午3:53


相关推荐

  • 大数据分析系统[通俗易懂]

    大数据分析系统[通俗易懂]1. 概念、分类数据分析系统的主要功能是从众多外部系统中,采集相关的业务数据,集中存储到系统的数据库中。系统内部对所有的原始数据通过一系列处理转换之后,存储到数据仓库的基础库中;然后,通过业务需要进行一系列的数据转换到相应的数据集市,供其他上层数据应用组件进行专题分析或者展示。根据数据的流转流程,一般会有以下几个模块:数据收集(采集)、数据存储、数据计算、数据分析、数据展示等等。当然也会有…

    2022年5月8日
    53
  • C中GridView控件的使用

    C中GridView控件的使用C 中 GridView 控件的使用一 GridView 和 DataGrid 的异同 GridView 是 DataGrid 的后继控件 在 framework2 中 虽然还存在 DataGrid 但是 GridView 已经走上了历史的前台 取代 DataGrid 的趋势已是势不可挡 GridView 和 DataGrid 功能相似 都是在 web 页面中显示数据源中的数据 将数据源中的一行数据 也就是一条记录

    2026年3月17日
    1
  • 【23】进大厂必须掌握的面试题-50个spring面试

    点击上方“全栈程序员社区”,星标公众号 重磅干货,第一时间送达 让我们从Spring面试问题的第一部分开始,即“一般问题”。 一般问题–Spring面试问题 1.不同版本的Spri…

    2021年6月24日
    134
  • ubuntu以root用户登录_ubuntu root登陆

    ubuntu以root用户登录_ubuntu root登陆一、设置root密码在桌面打开终端,或者使用ssh登录,(默认有一个登录账户)例如:sjlsjl1234561、输入命令:sudopasswdroot2、将会提示输入当前用户密码:3、提示输入新的Unix密码,此时输入要设置的root密码,提示输入新的Unix密码,此时再输入一次root密码。4、提示passwd.已成功更新密码,运行命令suroot,提示“密码:”此时输入刚刚设置的root密码回车,切换root用户成功。二、u…

    2025年7月7日
    8
  • IC Compiler II(ICC II)后端设计流程——超详细

    IC Compiler II(ICC II)后端设计流程——超详细Content 文章目录 ContentBlock AppOptions Finding ApplyingAppl InScriptEdit icc2 lm

    2026年3月20日
    1
  • 激活函数ReLU、Leaky ReLU、PReLU和RReLU

    激活函数ReLU、Leaky ReLU、PReLU和RReLU“激活函数”能分成两类——“饱和激活函数”和“非饱和激活函数”。sigmoid和tanh是“饱和激活函数”,而ReLU及其变体则是“非饱和激活函数”。使用“非饱和激活函数”的优势在于两点:1.首先,“非饱和激活函数”能解决所谓的“梯度消失”问题。2.其次,它能加快收敛速度。Sigmoid函数需要一个实值输入压缩至[0,1]的范围σ(x)=1/…

    2022年6月15日
    37

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号