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

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

相关推荐
weixin_456904271 天前
跨域(CORS)和缓存中间件(Redis)深度解析
redis·缓存·中间件
优秀的老黄4 天前
Docker部署RabbitMQ
linux·运维·docker·中间件·容器·centos·rabbitmq
Thuni_soft5 天前
华宇TAS应用中间件与瀚高股份两款产品完成兼容互认证
中间件
蒋星熠5 天前
中间件架构设计与实践:构建高性能分布式系统的核心基石
开发语言·数据库·分布式·python·中间件·性能优化·硬件工程
jc06206 天前
4.1-中间件之Redis
数据库·redis·中间件
lingggggaaaa7 天前
小迪安全v2023学习笔记(八十讲)—— 中间件安全&WPS分析&Weblogic&Jenkins&Jetty&CVE
笔记·学习·安全·web安全·网络安全·中间件·wps
MySGDLife7 天前
中间件八股
中间件
Mr_hwt_1237 天前
基于MyCat 中间件实现mysql集群读写分离与从库负载均衡教程(详细案例教程)
数据库·mysql·中间件·mysql集群
echoyu.8 天前
消息队列-初识kafka
java·分布式·后端·spring cloud·中间件·架构·kafka
Ray Song8 天前
【FastDDS】XML profiles
xml·中间件·自动驾驶·dds·fastdds