宿主机与容器通过 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这个话题。

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

相关推荐
墨鸦_Cormorant2 天前
MQTT(轻量级消息中间件)基本使用指南
mqtt·中间件·消息中间件
Python私教4 天前
从“Hello World”到“高并发中间件”:Go 语言 2025 系统学习路线图
学习·中间件·golang
UrSpecial4 天前
进程间通信:消息队列
中间件
EndingCoder7 天前
Next.js 中间件:自定义请求处理
开发语言·前端·javascript·react.js·中间件·全栈·next.js
十五年专注C++开发7 天前
通信中间件 Fast DDS(一) :编译、安装和测试
linux·c++·windows·中间件·cmake·vcpkg
在未来等你9 天前
RabbitMQ面试精讲 Day 17:消费者调优与并发消费
中间件·面试·消息队列·rabbitmq
茶茶只知道学习10 天前
Express中间件和路由及响应方法
中间件·express
汪随安10 天前
Dokcer创建中间件环境
中间件
在未来等你11 天前
RabbitMQ面试精讲 Day 16:生产者优化策略与实践
中间件·面试·消息队列·rabbitmq