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

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

在 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。


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

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

  • 13
    点赞
  • 19
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值