开发者学堂课程干货总结——Dubbo 分布式服务治理实践(三)

简介: Dubbo 分布式服务治理实践课时3——Dubbo2.0分布式RPC协议解析 。电子书+视频为同学带来最佳学习效果,文字、课程链接、图谱地址统统为大家放送了哦!

哈喽各位同学们大家好呀,小编今天带着开发者学院中课程Dubbo2.0分布式RPC协议解析  ”干货总结来了~一起学习新课程吧!

课程链接以及图谱地址小编已经为大家指路了,搭配学习效果更佳👇

课程名称:Dubbo2.0分布式RPC协议解析  

课程地址:https://developer.aliyun.com/learning/course/72/detail/1187?spm=a2c6h.12873639.0.0.70672e8aSWMLvg

图谱名称:Alibaba Java 技术图谱

图谱地址:https://developer.aliyun.com/graph/java?spm=a2c6h.21110250.J_5703890090.6.700e3c67EjOBeJ


Dubbo2.0分布式RPC协议解析


()Dubbo分布式RPC协议解析 

DubboRPC基础上改造的一套框架底层分时通信的基础设施没变,主要是在协议层另做了一层封装,封装思路大规模服务集群治理希望支持更多协议,不仅仅是Webservice,或者REST API这种风格的通信,而是直接封装的服务接口,发送授信协议进行通信基于汽车网络协议中的MQTT再次封装 

企业局域网通信,即使公网通信,有些平台也希望定制自己的协议,典型代表QQ微信阿里钉钉,封闭的聊天系统里面通信很多,Dubbo是自定义协议,实际在此基础上提供协议的再次封装,如在TCP基础上,不仅支持REST,传统跨平台跨语言的企业级行业协议,另外会做一些协议扩展,效率方面有更高要求,希望原生的TCP或者UDP基础上,在二进制数据包上做封装 

 Dubbo的封装规定严格华为自定了一套通信加密协议,协议基于GDPUDP协议进行封装,一种格式协议,只有自己能解析QQ或者微信的协议,只有腾讯解析Dubbo思想也参考了经典分布式网络通信中的分包定义格式思想规范。 

image.png 

如上图所示, 

1-4 Version; 

5-8 Header Length; 

8-13 DifferentiatedServicesCodePoint 

14-15 ExplicitCongestionNotification 

16-18 ,19-31 Totall Length 

... 

每个比特位都有严格定义这种严格的消息定义主要用于自定义 Dubbo的通信协议编码指的是 Dubbo的自定义消息编码的格式规范。 

同样解码需要获取IP地址有效的消息载体都有严格定义,定义的字段越丰富,消息通信的语义功能越强大消息的封装也越复杂,如只留1个字节8个比特作为这个消息的额外信息后面的话全是消息有效体,消息有效载体利用率就较高。 

上图中,总共有128个比特这里作为前置所有消息的扩展定义第一阶段IP包然后 TCP包的封装,Dubbo消息包括封装序列化ID魔术编码的比特位、状态码等。 

Dubbo在原始的iptcp协议之上进行了再次封装,在对象或者数据传时候序列化,序列二进制格式这样效率更高如果JSON涉及到更复杂的编码问题。实际上Dubbo的整个原生协议封装足够复杂,128比特位自己定义用于16个字节,有效载荷就比较浪费 

Dubbo除了自定义协议的设计思想外,也其他几个典型聊天软件已对比的用标准协议,有自定义协议自定义协议封闭性更强效率更高行业标准协议虑跨平台的通用性安全性问题 

高级面试题:Dubbo支持的协议  

Dubbo支持多种协议: 

1.基于TCP协议 Netty、Mina实现 

2.Dubbo协议(默认) 

3. Hessian协议 

4. HTTP协议 

5. RMI协议 

6. WebService协议  

7. Thrift协议 

8. Memcached协议 

9. Redis协议  

10.gPRC  

11.Http2.0 

Dubbo协议支持足够丰富现在做分布式开发,Dubbo是非常优秀分布式框架扩展,通信协议的支持已经在GRPC足够优秀,强大的地方在于做大规模集群的服务治理 Dubbo不仅是一套思想更是能落地且经过阿里大规模服务实践落地检验 

(三)Dubbo默认协议  

1. Dubbo 协议默认使用Hessian2 序列化。(说明: Hessian2 是阿里在 Hessian 基础上进行的二次开发, 起名为Hessian2 )  

2. rmi协议 默认为 java 原生序列 

3. http协议 默认为 json 

4. hessian 协议,默认是 hessian 序列化 

5. webservice 协议,默认是 soap 文本序列化  

局域网方面Dubbo的原则协议已经足够优秀多种协议的好处在于可灵活根据自己的场景定制选择,允许自定义,为更复杂高级的场景允许扩展的接口 

(四)Dubbo线程消息分发模型 

•Dispatcher 分发器  

• all, direct, message, execution, connection  

ThreadPool 线程池  

• fixed, cached 

Dubbo线程消息分发模型就是客户端和和服务端进行通讯另外里面涉及到消息体的问题,消息体占多大作为消息封装框架要考虑功能效率问题 

(五)Dubbo提供的注册中心  

  1. Multicast注册中心 

2. Zookeeper注册中心  

3. Redis注册中心  

4. Simple注册中心 

相关文章
|
16天前
|
JavaScript 文件存储 数据安全/隐私保护
打造你的私人电子书王国:Talebook 项目全面介绍
Talebook 以其简洁的部署、优雅的界面和强大的功能,成为了这个领域不可多得的好项目。
305 127
|
17天前
|
Web App开发 数据采集 前端开发
如何在VSCode中查看、转换markdown文件:使用MPE(Markdown Previe Enhanced)插件
本文介绍了在VSCode中使用MPE插件处理Markdown文件的方法。主要内容包括:1)MPE插件的安装;2)查看Markdown渲染效果的两种方式(内置快捷键和MPE右键预览);3)Markdown文件转换功能,详细讲解了导出HTML(离线/在线模式)、PDF(Chrome/Prince/Pandoc三种方式)和Word的操作步骤及注意事项。文章还提供了相关软件的安装指南和常见问题解决方案,帮助用户更好地使用MPE插件进行Markdown文档处理。
如何在VSCode中查看、转换markdown文件:使用MPE(Markdown Previe Enhanced)插件
|
17天前
|
边缘计算 安全 定位技术
AIWCLOUD:免备案高防CDN、不限内容、抗投诉、在跨境金融级数据同步场景下
本文介绍一种专为跨境金融设计的免备案CDN架构,通过物理路径固化、PTP亚微秒时钟同步与MACsec链路层加密,实现低抖动、高安全、强合规的“数据专线级”传输,满足支付清算、外汇交易等场景的严苛要求。(239字)
160 8
|
16天前
|
弹性计算 运维 负载均衡
2026阿里云价格最低云服务器选购攻略:轻量38元起、经济型99元、u1实例199元对比与选购指南
本文介绍了2026年阿里云服务器的三大高性价比产品线及其选购策略。轻量应用服务器主打极致性价比,2核2G配置年费低至38元(限时抢购),2核4G配置199元/年,适合个人开发者及小微企业快速建站。经济型e实例ECS以99元/年的新购续费同价政策,成为入门级用户的首选。通用算力型u1实例199元/年、u2i实例约900元起,则面向小型企业及关键业务场景,提供独享算力与企业级稳定性。本文通过配置、价格、适用场景的系统对比,帮助用户根据业务规模和需求选型。
|
16天前
|
弹性计算 人工智能 运维
199元/年!阿里云2核4G配置云服务器活动价格与选购指南:配置解析+适用场景及购买指南
2026年阿里云2核4G配置云服务器的特惠方案:轻量应用服务器2核4G(200M峰值带宽、50G ESSD云盘)抢购价199元/年,9.9元/月,适合个人开发者快速部署AI应用(如OpenClaw)。云服务器ECS通用算力型u1实例2核4G5M带宽同样199元/年,独享资源、新购续费同价,是企业用户性价比之选。此外还有经济型e实例99元/年、u2i实例680元起及c9i实例1742元起等多档可选。建议新用户追求快速上手选轻量应用服务器,企业稳定运营选u1实例,高并发高性能需求则考虑u2i或c9i实例。
|
16天前
|
域名解析 运维 网络协议
网站测速实用方法及性能评估要点
网站的访问速度直接关系用户使用体验,也是衡量服务器运行状态、网络链路质量、站点优化效果的关键指标。在日常网站运维管理中,通过规范的测速方式,能够及时发现页面加载缓慢、地域访问差异、连接不稳定等问题,为后续优化调整提供有效参考。
266 0
|
16天前
|
机器学习/深度学习 人工智能 算法
Ring-2.6-1T 正式开源:为真实复杂任务打造的万亿级思考模型
蚂蚁百灵开源万亿级思考模型Ring-2.6-1T,专注真实复杂任务场景。具备强Agent执行能力、可调high/xhigh推理强度、异步强化学习训练三大突破,已在代码生成、科研分析、企业自动化等长链路任务中验证稳定表现。
311 1
|
17天前
|
人工智能 自然语言处理 测试技术
大模型应用:Skill架构解析:理解大模型Skill的本质、核心组成和本地模型实践.116
本文以极简数字计算Skill为切入点,深入浅出解析大模型Skill本质:模块化、可触发、结构化返回。通过零依赖代码示例,完整呈现Skill四大核心环节——配置声明、参数提取、逻辑执行、结果整合,并延伸至本地Qwen模型实现关键词提取实战,助开发者快速掌握Skill开发范式。
388 2
|
18天前
|
人工智能 机器人 API
全网首发:Open claw配置VoceChat聊天超详细教程
VoceChat是轻量(15MB)可私有部署的加密聊天服务,适合NAS/个人服务器;OpenClaw是开源AI执行引擎,能将自然语言指令转化为真实操作。本教程详解二者集成:通过VoceChat作为前端入口,远程调用本地部署的OpenClaw“龙虾”智能体,实现AI从对话到行动的闭环。
202 0
|
18天前
|
人工智能 前端开发 JavaScript
浏览器自动化的下一层:为什么 CloakBrowser 把指纹问题推到了源码层?
CloakBrowser 是一款基于 Chromium 源码级改造的反检测浏览器工具,通过 C++ 层补丁修复 Canvas、WebGL、字体、GPU、WebRTC 等指纹特征,并模拟真实用户行为,提升自动化环境可信度。它不绕验证码,而是从根源降低被风控识别概率,适用于测试开发、AI Agent 及合规爬虫场景。

热门文章

最新文章