宿主机与容器通过 rmw_cyclonedds_cpp中间件进行ros2结点之间的通讯的相关注意事项

宿主机与容器通过 rmw_cyclonedds_cpp中间件进行ros2结点之间的通讯的相关注意事项

rmw_cyclonedds_cpp是什么

一种ros2框架体系中的中间件通讯方式,与之相对的另一种常用的中间件通讯方式是rmw_fastrtps_cpp

Fast DDS (rmw_fastrtps_cpp) 功能很全、可配置性强,但默认依赖多播发现,跨宿主机/容器时容易遇到"发现通但数据不通"的问题,需要手动配置网卡和端口才能稳定.

而 Cyclone DDS (rmw_cyclonedds_cpp) 设计更简洁,对网络环境更友好,几乎开箱即用,在 Docker、不同机器或复杂网络下通信更稳定,因此社区里常推荐 CycloneDDS 做跨设备通信。

最近有一个场景,需要用到rmw_cyclonedds_cpp. 构建宿主机与容器的ros2结点通讯.

构建容器与宿主机之间的ros2结点通讯

我发现几个很有趣的现象

  1. 如果我在宿主机和容器中都设置了export RMW_IMPLEMENTATION=rmw_cyclonedds_cpp,此时尽管任意一方可以通过ros2 topic list查看到/chatter话题
    容器:

    宿主机:

    但是talker发送的消息,listener收不到
    宿主机:

    容器:

    反过来也是如此.在容器中,talker发送消息给/chatter话题,宿主机无法接受到chatter话题中相关的消息.

当只在一方进行export RMW_IMPLEMENTATION=rmw_cyclonedds_cpp的设置,就可以正常接受信息了.

  1. 如果你是希望宿主机端执行export RMW_IMPLEMENTATION=rmw_cyclonedds_cpp命令,需要注意这个命令不能写在宿主机的~/.bashrc中,只能显式地在宿主机控制台进行输入.否则会出现如下情况,容器收不到chatter话题的消息,但是容器知道有chatter这个话题。

这个问题产生的原因我目前也找不到头绪。

相关推荐
青火coding1 天前
SOFAServerless架构的意义
java·运维·中间件·架构·serverless
马士兵教育2 天前
AI大模型通用智能体项目从原理到落地:Agent Skills 的核心逻辑与中间件 + 动态工具实践方案+架构项目实战!
人工智能·中间件·架构
米优5 天前
使用Qt实现消息队列中间件动态库封装
c++·中间件·rabbitmq
小丑小丑小丑5 天前
【AP AUTOSAR】COM通信模块api详解
中间件·汽车·autosar·autosar ap
信创天地5 天前
信创环境下数据库与中间件监控实战:指标采集、工具应用与告警体系构建
java·运维·数据库·安全·elk·华为·中间件
小唐同学爱学习6 天前
布隆过滤器
java·spring boot·中间件
flyyyya6 天前
【AI学习从零至壹】langchain1.0中间件
人工智能·学习·中间件
General_G7 天前
irobot_benchmark的编译和使用
linux·中间件·机器人·ros2
burning_maple7 天前
设计数据密集型应用阅读笔记
分布式·后端·中间件
星辰_mya8 天前
零拷贝之浅入深出
中间件·架构