开发者学堂课程干货总结——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注册中心 

相关文章
|
Java 程序员 调度
【JAVA 并发秘籍】进程、线程、协程:揭秘并发编程的终极武器!
【8月更文挑战第25天】本文以问答形式深入探讨了并发编程中的核心概念——进程、线程与协程,并详细介绍了它们在Java中的应用。文章不仅解释了每个概念的基本原理及其差异,还提供了实用的示例代码,帮助读者理解如何在Java环境中实现这些并发机制。无论你是希望提高编程技能的专业开发者,还是准备技术面试的求职者,都能从本文获得有价值的见解。
219 1
|
存储 前端开发 API
前端开发中,Web Storage的存储数据的方法localstorage和sessionStorage的使用及区别
前端开发中,Web Storage的存储数据的方法localstorage和sessionStorage的使用及区别
469 0
|
监控 安全 前端开发
【Azure 应用服务】App Service 运行状况健康检查功能简介 (Health check)
【Azure 应用服务】App Service 运行状况健康检查功能简介 (Health check)
455 0
|
存储 关系型数据库 数据库
OceanBase数据库常见问题之修改日志盘的数据存储路径后控件不生效如何解决
OceanBase 是一款由阿里巴巴集团研发的企业级分布式关系型数据库,它具有高可用、高性能、可水平扩展等特点。以下是OceanBase 数据库使用过程中可能遇到的一些常见问题及其解答的汇总,以帮助用户更好地理解和使用这款数据库产品。
|
SQL 消息中间件 Kafka
Apache Hudi测试、运维操作万字总结
Apache Hudi测试、运维操作万字总结
564 1
|
数据采集 存储 数据可视化
微博数据可视化分析:利用Python构建信息图表展示话题热度
微博数据可视化分析:利用Python构建信息图表展示话题热度
|
人工智能 关系型数据库 分布式数据库
活动预告 | 12月16日"国产数据库共话未来趋势"线下沙龙 杭州站欢迎您的到来!
12月16日周六,PolarDB开源社区联合PostgreSQL中文社区、Ninedata共同举办以“国产数据库公话未来趋势”为主题的技术沙龙,本次沙龙我们邀请了众多国产数据库领域的专家,对当前的数据库技术进行探讨和讨论。
|
Linux
如何在Linux系统上查看CPU使用率?
以上命令可以帮助你监视和分析Linux系统中的CPU使用率,可以根据需要选择合适的命令进行查看。 买CN2云服务器,免备案服务器,高防服务器,就选蓝易云。百度搜索:蓝易云
701 0
|
Java 关系型数据库 数据库连接
mybatis-plus学习
MyBatis-Plus ,MyBatis 最佳搭档,只做增强不做改变,为简化开发、提高效率而生。
176 5
|
XML Java 数据格式
掌握Spring Environment:配置管理的关键
掌握Spring Environment:配置管理的关键
604 1