阐述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

相关文章

如何在Spring Boot项目中集成MQTT协议

《如何在SpringBoot项目中集成MQTT协议》本文介绍在SpringBoot中集成MQTT的步骤,包括安装Broker、添加EclipsePaho依赖、配置连接参数、实现消息发布订阅、测试接口... 目录1. 准备工作2. 引入依赖3. 配置MQTT连接4. 创建MQTT配置类5. 实现消息发布与订阅

使用Python进行GRPC和Dubbo协议的高级测试

《使用Python进行GRPC和Dubbo协议的高级测试》GRPC(GoogleRemoteProcedureCall)是一种高性能、开源的远程过程调用(RPC)框架,Dubbo是一种高性能的分布式服... 目录01 GRPC测试安装gRPC编写.proto文件实现服务02 Dubbo测试1. 安装Dubb

Dubbo之SPI机制的实现原理和优势分析

《Dubbo之SPI机制的实现原理和优势分析》:本文主要介绍Dubbo之SPI机制的实现原理和优势,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Dubbo中SPI机制的实现原理和优势JDK 中的 SPI 机制解析Dubbo 中的 SPI 机制解析总结Dubbo中

Nginx中配置HTTP/2协议的详细指南

《Nginx中配置HTTP/2协议的详细指南》HTTP/2是HTTP协议的下一代版本,旨在提高性能、减少延迟并优化现代网络环境中的通信效率,本文将为大家介绍Nginx配置HTTP/2协议想详细步骤,需... 目录一、HTTP/2 协议概述1.HTTP/22. HTTP/2 的核心特性3. HTTP/2 的优

springboot+dubbo实现时间轮算法

《springboot+dubbo实现时间轮算法》时间轮是一种高效利用线程资源进行批量化调度的算法,本文主要介绍了springboot+dubbo实现时间轮算法,文中通过示例代码介绍的非常详细,对大家... 目录前言一、参数说明二、具体实现1、HashedwheelTimer2、createWheel3、n

关于WebSocket协议状态码解析

《关于WebSocket协议状态码解析》:本文主要介绍关于WebSocket协议状态码的使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录WebSocket协议状态码解析1. 引言2. WebSocket协议状态码概述3. WebSocket协议状态码详解3

Qt 中集成mqtt协议的使用方法

《Qt中集成mqtt协议的使用方法》文章介绍了如何在工程中引入qmqtt库,并通过声明一个单例类来暴露订阅到的主题数据,本文通过实例代码给大家介绍的非常详细,感兴趣的朋友一起看看吧... 目录一,引入qmqtt 库二,使用一,引入qmqtt 库我是将整个头文件/源文件都添加到了工程中进行编译,这样 跨平台

Java如何接收并解析HL7协议数据

《Java如何接收并解析HL7协议数据》文章主要介绍了HL7协议及其在医疗行业中的应用,详细描述了如何配置环境、接收和解析数据,以及与前端进行交互的实现方法,文章还分享了使用7Edit工具进行调试的经... 目录一、前言二、正文1、环境配置2、数据接收:HL7Monitor3、数据解析:HL7Busines

【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(