当前位置: 首页 > news >正文

干翻Dubbo系列第十一篇:Dubbo常见协议与通信效率对比

文章目录

文章说明

一:协议

1:什么是协议

2:协议和序列化关系

3:协议组成

(一):头信息

(二):体信息

4:Dubbo3中常见的协议

 5:不同协议的通信效率比较


文章说明


本文内容整理自《孙哥说Dubbo系列视频课程》,孙帅老师课程细致、全面、深入、性价比极高。B站搜孙帅suns可以找到对应的试听视频,或者直接添加老师微信号suns45与他直接联系

一:协议

1:什么是协议

客户端[消费者]与服务端[提供者]在传输数据时双⽅的约定。

大致就是除了咱们通信双方需要传递的真实数据(体信息)还包括大量的描述信息,这个描述信息被称为头信息。数据传递过去之后,经过反序列化,然后按照协议的描述信息进行拆解传递的数据就可以拿到最终的真实传递的数据,也就是体信息,比如咱们Http请求的请求参数或者是RPC时候的方法的参数。

2:协议和序列化关系

序列化是协议数据的传输⼀种格式。⽬的是为了提⾼协议在⽹络传输的效率。

同样的协议化数据,经过不同的序列化手段序列化之后,在网络传输中传输的大小是不一致的,具有不同的传输效率和对方想要获取到你实际的协议数据,也需要进行反序列化获取相应的协议数据,然后进行拆解,最终获取到真实的传输数据。

3:协议组成

(一):头信息

幻术:为了约束双方的新人关系,证明这是标准的通信数据的一种格式数据,相当于是通信双方的街头暗号。想要通信,暗号不能错!

序列化方式:数据传输的过程中,我们使用的是什么序列化方式,知道了序列化方式之后,我们才能基于具体的序列化方式记性反序列化传输过来的数据,然后在拆解协议数据。

操作方向性:客户端给服务端发情求,还是服务端给客户端响应请求

状态信息:基本上就是服务端给客户端返回的状态信息

数据大小:数据大小指的是,协议体数据量的大小,解决半包粘包的问题。

(二):体信息

体信息就是数据想要传输的信息本身,比说上图中的JSON

4:Dubbo3中常见的协议

dubbo协议:

dubbo在默认情况下使用的是dubbo协议,这是Dubbo定义的私有协议,应用在TCP层次。

rest协议:

rest协议这里主要是Http协议。为什么rest协议也很重要,Dubbo支持这个协议之后,就可以跟SpringCloud进行无缝对接了。

triple协议:

Dubbo3开发的新协议。

grpc协议:

云原生时代,GRPC十分重要了,Dubbo想要与云原生进行结合,必须支持GRPC。

剩下还有:thrift协议 webservice协议、rocketmq协议、redis协议、memcached协议,了解就好,用的很少。

 5:不同协议的通信效率比较

看到这个东西我们可以明确两个概念:

1:不同的协议,可以挑选不同的序列化方案。

2:不同的序列化方案和通信协议组合,对应的通信效率也是有很大的差异。

http://www.lryc.cn/news/128174.html

相关文章:

  • 春秋云镜 CVE-2020-17530
  • 【java毕业设计】基于Spring Boot+Vue+mysql的论坛管理系统设计与实现(程序源码)-论坛管理系统
  • 华为在ospf area 0单区域的情况下结合pbr对数据包的来回路径进行控制
  • PyQt5登录界面跳转
  • git add 用法
  • 系统架构设计师---2018年下午试题1分析与解答(试题三)
  • 面试时如何回答接口测试怎么进行
  • 【LeetCode】647.回文子串
  • 【Git】SSH到底是什么
  • 当你出差在外时,怎样轻松访问远程访问企业局域网象过河ERP系统?
  • 机器学习与模型识别1:SVM(支持向量机)
  • 在CentOS7.9上安装最新版本Docker安装步骤
  • 基于 spring boot 的动漫信息管理系统【源码在文末】
  • vue项目根据word模版导出word文件
  • PHP 从 URL(链接) 字符串中获取参数
  • 第一百三十一天学习记录:数据结构与算法基础:栈和队列(下)(王卓教学视频)
  • 全球磁强计市场价值约为16.2亿美元,预测期内将以超过5.21%的增长率增长
  • WebGL游戏站优化实录【myshmup.com】
  • 6、Mysql免安装版本的配置与使用(2023-08)
  • docker之简介与安装
  • vue之动态表单(优化)
  • web连接桌面打开gptmap
  • 做好需求分析的4大关键认知
  • Max Compute 操作记录
  • Windows 11 + Ubuntu20.04 双系统 坑里爬起来
  • touch手势事件及功能封装
  • 面试问题记录
  • ZooKeeper的应用场景(集群管理、Master选举)
  • 面试算法编程题
  • JVM——JDK 监控和故障处理工具总结