阐述Dubbo协议

2024-03-22 08:20
文章标签 协议 dubbo 阐述

本文主要是介绍阐述Dubbo协议,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1 Dubbo协议概述

 Dubbo协议是建立在TCP(传输层协议)之上的一种应用程序协议。它参考了TCP协议栈中的协议,协议内容由header和body两部分组成。

2 协议头header的组成

协议头组成如下所示。

header格式
bit序号0-78-1516-2324-3132-9596-127
内容magic hightmagic lowrequest flag and
 serialization id
response statusrequest idbody length

由上可知,协议头总共包含了16个字节的数据。具体内容如下所述。

2.1 魔数

前2个字节为魔数。这里用来标识一个帧的开始,固定为0xdabb。第一个字节固定为0xda,第二个字节固定为0xbb。

// header length.
protected static final int HEADER_LENGTH = 16;
// magic header.
protected static final short MAGIC = (short) 0xdabb;
protected static final byte MAGIC_HIGH = Bytes.short2bytes(MAGIC)[0];
protected static final byte MAGIC_LOW = Bytes.short2bytes(MAGIC)[1];

2.2 请求类型和序列化类型ID

第3个字节是请求类型和序列化类型ID的组合结果。

(1)高3位标示请求类型,其枚举值如下所示。

protected static final byte FLAG_REQUEST = (byte) 0x80; //10000000 (100)
protected static final byte FLAG_TWOWAY = (byte) 0x40; //01000000 (010)
protected static final byte FLAG_EVENT = (byte) 0x20; //00100000 (001)

(2)低5位标示序列化方式,其枚举值如下所示。

/*** 序列化类型ID (用5个比特来存储该值)*/
public interface Constants {byte HESSIAN2_SERIALIZATION_ID = 2; // 0010 (00010)/*** JavaSerialization 的 序列化类型ID */byte JAVA_SERIALIZATION_ID = 3; // 0011  (00011)byte COMPACTED_JAVA_SERIALIZATION_ID = 4;byte FASTJSON_SERIALIZATION_ID = 6;byte NATIVE_JAVA_SERIALIZATION_ID = 7;byte KRYO_SERIALIZATION_ID = 8;byte FST_SERIALIZATION_ID = 9;byte NATIVE_HESSIAN_SERIALIZATION_ID = 10;byte PROTOSTUFF_SERIALIZATION_ID = 12;byte AVRO_SERIALIZATION_ID = 11;byte GSON_SERIALIZATION_ID = 16;byte PROTOBUF_JSON_SERIALIZATION_ID = 21;byte PROTOBUF_SERIALIZATION_ID = 22;byte FASTJSON2_SERIALIZATION_ID = 23;byte KRYO_SERIALIZATION2_ID = 25;/*** 最大不超过31,因为只有5个比特用于存储序列化类型ID*/byte CUSTOM_MESSAGE_PACK_ID = 31; // 11111 (11111)
} 

这篇关于阐述Dubbo协议的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/834916

相关文章

【Linux】应用层http协议

一、HTTP协议 1.1 简要介绍一下HTTP        我们在网络的应用层中可以自己定义协议,但是,已经有大佬定义了一些现成的,非常好用的应用层协议,供我们直接使用,HTTP(超文本传输协议)就是其中之一。        在互联网世界中,HTTP(超文本传输协议)是一个至关重要的协议,他定义了客户端(如浏览器)与服务器之间如何进行通信,以交换或者传输超文本(比如HTML文档)。

【Go】go连接clickhouse使用TCP协议

离开你是傻是对是错 是看破是软弱 这结果是爱是恨或者是什么 如果是种解脱 怎么会还有眷恋在我心窝 那么爱你为什么                      🎵 黄品源/莫文蔚《那么爱你为什么》 package mainimport ("context""fmt""log""time""github.com/ClickHouse/clickhouse-go/v2")func main(

2024.9.8 TCP/IP协议学习笔记

1.所谓的层就是数据交换的深度,电脑点对点就是单层,物理层,加上集线器还是物理层,加上交换机就变成链路层了,有地址表,路由器就到了第三层网络层,每个端口都有一个mac地址 2.A 给 C 发数据包,怎么知道是否要通过路由器转发呢?答案:子网 3.将源 IP 与目的 IP 分别同这个子网掩码进行与运算****,相等则是在一个子网,不相等就是在不同子网 4.A 如何知道,哪个设备是路由器?答案:在 A

Modbus-RTU协议

一、协议概述 Modbus-RTU(Remote Terminal Unit)是一种基于主从架构的通信协议,采用二进制数据表示,消息中的每个8位字节含有两个4位十六进制字符。它主要通过RS-485、RS-232、RS-422等物理接口实现数据的传输,传输距离远、抗干扰能力强、通信效率高。 二、报文结构 一个标准的Modbus-RTU报文通常包含以下部分: 地址域:单个字节,表示从站设备

网络原理之TCP协议(万字详解!!!)

目录 前言 TCP协议段格式 TCP协议相关特性 1.确认应答 2.超时重传 3.连接管理(三次握手、四次挥手) 三次握手(建立TCP连接) 四次挥手(断开连接)  4.滑动窗口 5.流量控制 6.拥塞控制 7.延迟应答 8.捎带应答  9.基于字节流 10.异常情况的处理 小结  前言 在前面,我们已经讲解了有关UDP协议的相关知识,但是在传输层,还有

Dubbo学习入门

本文参考自:Dubbo用户手册(中文)http://dubbo.apache.org/books/dubbo-user-book/ 现在的参考文档地址:http://dubbo.apache.org/zh-cn/docs/user/quick-start.html 入门请参考自《Dubbo用户手册(中文)》第一节,在手册第二节说明如何快速启动Dubbo,下面就顺着手册的使用方式,自己搭建一个快

DNS协议基础笔记

1.定义 DNS(Domain Name System,域名系统)是互联网的一项核心服务,它作为将域名和 IP 地址相互映射的一个分布式数据库,能够使人更方便地访问互联网。 2.域名解析过程 当用户在浏览器中输入一个域名,浏览器首先会检查自己的缓存中是否有该域名对应的 IP 地址。本地 DNS 服务器收到查询请求后,首先会检查自己的缓存中是否有该域名对应的 IP 地址。根域名服务器收到查询请

4G模块、WIFI模块、NBIOT模块通过AT指令连接华为云物联网服务器(MQTT协议)

MQTT协议概述 MQTT(Message Queuing Telemetry Transport)是一种轻量级的消息传输协议,它被设计用来提供一对多的消息分发和应用之间的通讯,尤其适用于远程位置的设备和高延迟或低带宽的网络。MQTT协议基于客户端-服务器架构,客户端可以订阅任意数量的主题,并可以发布消息到这些主题。服务器(通常称为MQTT Broker)则负责接受来自客户端的连接请求,并转发消

HTTP协议 HTTPS协议 MQTT协议介绍

目录 一.HTTP协议 1. HTTP 协议介绍 基本介绍: 协议:  注意: 2. HTTP 协议的工作过程 基础术语: 客户端: 主动发起网络请求的一端 服务器: 被动接收网络请求的一端 请求: 客户端给服务器发送的数据 响应: 服务器给客户端返回的数据 HTTP 协议的重要特点: 一发一收,一问一答 注意: 网络编程中,除了一发一收之外,还有其它的模式 二.HTT

dubbo服务过程

dubbo服务暴露过程 Dubbo通过实现ApplicationListener接口,监听了容器刷新的事件,再容器刷新后调用onApplicationEvent方法,这个是服务暴露的启动点通过识别带目标注解的服务类通过动态代理统一暴露出Invoker,如何通过配置文件以及目标协议(SPI机制)封装成exporter存储起来如果是本地注册,将exporter存入ServiceConfig的缓存,如