ROS2 王牌升级:Fast-DDS 性能直接碾压 zeroMQ 「上」

以下内容为本人的学习笔记,如需要转载,请声明原文链接 微信公众号「ENG八戒」mp.weixin.qq.com/s/aU1l3HV3a...

在 ROS 开发小组的努力下, ROS 从 ROS1 迭代到 ROS2 后通信性能提升非常大,关键是将优秀的 DDS 通信协议作为 ROS2 的内部通信协议规范,而默认的协议实现更是直接采用了 Fast-DDS。

以八戒之前所在的开发团队技术栈来看,机器人内部多节点架构,一般都习惯采用分布式技术,其中的消息中间件就是采用了 zeroMQ 作为通信底层,优点就是轻量和异步高性能。为此,八戒不禁对 ROS 采用的这款 DDS 实现顿生兴趣,其中必有不得了的优势。

找了下官网的资料,发现官网之前就以 zeromq 为对标做了一番非常详细的性能对比,看来 Fast-DDS 官方还是比较了解市场的,功夫下得足。Fast-DDS 是最新的名称,原名叫 Fast RTPS。

数据传输的另类模式:发布订阅制

目前技术栈里,绝大部分的可用中间件都是基于请求回复的模式,比如 Web 服务,Rest API,Apache Thrift 开发框架,RMI(远程方法调用)等,数据传输都是由一方发起请求,而另一方回复请求内容。

请求回复制,这种经典模式其实非常符合人的思维,你需要什么你就去找什么,请求的一方掌握主动,闲来无事互不打扰。你也不希望有人一整天都在你耳边唠叨个不停。

但是真实世界里往往有一些不太自然的一面,数据传输也不会只依靠一种模式就可以通吃。

在物理世界里,数据的采集其实是一直在发生的,比如各种传感器就会一直生产数据并反馈给中枢处理器,如果这点不好理解,试想一下你的身体是不是一直在感受(采集)周围环境的信息(数据),那么这类情景中还采用请求回复的模式就比较低效率了。

故而,一旦数据发布者发布数据,对这些感兴趣的订阅者(已订阅)就可以接收数据,这就是发布订阅模式。

发布订阅制:有什么好处

  1. 在性能方面,可以做到更低的延迟和更高的数据吞吐量。

  2. 数据两端解耦性更佳,数据生产者不用关心数据被谁接收使用,只负责生产数据,数据消费者不用关心谁负责生产数据,只需要尽量消费数据。

基于分布式系统的广泛应用需求,Fast RTPS 和 ZeroMQ 都是实现了发布订阅模式的异步消息中间件。

ZeroMQ

ZeroMQ 是一个不需要消息代理的异步消息中间件,实现了多种通信模式,除了发布订阅模式,也包括请求回复模式。提供的库 API 类似 socket API,但不包含数据序列化和逆序列化的功能,需要开发者自行实现。

Fast RTPS

Fast RTPS 是实时发布订阅协议(Real-Time Publish Subscribe protocol)的一个高性能实现,提供了简单的发布订阅 API,并且相关库 fast Buffers 也提供了数据序列化和逆序列化的支持。如果需要用到其它消息分发模式,可以使用相关库 RPC over DDS。


全文未结束,本文只是上篇。如果各位同学朋友有什么疑问可以联系笔者,当然笔者也愿意和你进一步探讨这方面的问题。另外,八戒有自己的技术圈朋友群,如果读者朋友想进群交流技术问题,欢迎联系我。

最后,非常感激各位朋友的点 「赞」 和点击 「在看」,谢谢!

相关推荐
蝎蟹居6 小时前
GBT 4706.1-2024逐句解读系列(26) 第7.6条款:正确使用符号标识
人工智能·单片机·嵌入式硬件·物联网·安全
送外卖的工程师9 小时前
STM32F103 驱动 BMP280 气压温湿度传感器 + OLED 显示教程
stm32·单片机·嵌入式硬件·mcu·物联网·proteus·rtdbs
专业开发者10 小时前
NXP解析蓝牙 ® 声道探测技术将如何赋能汽车数字钥匙
人工智能·物联网·汽车
得一录14 小时前
Android AIDL 在智能体和IOT设备中的使用
android·人工智能·物联网·aigc
sdyeswlw15 小时前
实力认证 !一二三物联网微功耗遥测终端入选济南市创新产品应用推荐目录
物联网
深圳博达智联15 小时前
博达智联供水4G控制器方案:厂家集中管控,终端用户手机远程控,运维成本降一半
物联网·智能手机·人机交互
云里物里16 小时前
物联网电子墨水屏安装配件汇总介绍!
物联网·电子价签·电子标签·电子墨水屏标签·电子标签系统
安科瑞刘鸿鹏1719 小时前
企业能源物联网,本质是一场数据整合能力的较量
运维·数据库·物联网·能源
国产化创客19 小时前
轻量化年龄识别模型SSR-Net在树莓派部署测试
linux·物联网·边缘计算·智能硬件
Tel199253080041 天前
全新C-Components高压继电器P/N 500-214
单片机·物联网·自动化·工业自动化