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。


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

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

相关推荐
中科岩创2 小时前
榆能横山煤电厂及周边建筑物爆破振动和位移自动化监测
物联网
光路科技14 小时前
八大网络安全策略:如何防范物联网(IoT)设备带来的安全风险
物联网·安全·web安全
委员19 小时前
基于NodeMCU的物联网空调控制系统设计
单片机·mcu·物联网·智能家居
逝灮21 小时前
【蓝桥杯——物联网设计与开发】拓展模块3 - 温度传感器模块
驱动开发·stm32·单片机·嵌入式硬件·物联网·蓝桥杯·温度传感器
邓校长的编程课堂21 小时前
基于树莓派Pico和声音传感器实现声控风扇的技术分享
物联网·嵌入式开发·树莓派pico·编程入门·c++编程·声音传感器·c++趣味编程
有续技术1 天前
工厂常用软件系统大全中英文全称对照表及功能介绍应用场景ERP MES WMS SCADA IOT SAP等软件系统介绍
物联网
嗯? 嗯。2 天前
遇见物联网
物联网
神一样的老师2 天前
物联网:全面概述、架构、应用、仿真工具、挑战和未来方向
物联网
深圳博达智联2 天前
V900新功能-电脑不在旁边,通过手机给PLC远程调试网关配置WIFI联网
物联网
TDengine (老段)2 天前
TDengine 新功能 通过 UID 删除不可见表
大数据·数据库·物联网·时序数据库·tdengine