ROS2网络多机通信DDS和安全加密SROS(多机器人系统)

2024-03-27 12:59

本文主要是介绍ROS2网络多机通信DDS和安全加密SROS(多机器人系统),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

ROS1多机通信配置较为繁琐,但是ROS2非常简单,直接通过DDS实现。

如果是局域网,只需确保ROS_DOMAIN_ID一致即可。

例如设置ID为5:export ROS_DOMAIN_ID=5。

所有网络中设置一致,即可通信。()

PC1:

PC1开启订阅器

PC2:

/topic

可以查看开启前后主题多了一个/topic。

在PC2开启发布器:

publisher

PC1:

PC1收到消息

思考题:尝试通过网络控制turtlesim和turtlebot3。


ROS1和ROS2都支持消息加密以提高安全性。

ROS1:http://wiki.ros.org/SROS

SROS是ROS的一组安全性增强功能,例如对ROS中所有套接字传输的本机TLS支持,使用x.509证书(允许信任链),可定义的名称空间(针对ROS节点限制和允许的角色)以及契约用户-space工具自动生成节点密钥对,审核ROS网络以及构造/训练访问控制策略。此外,还提供了AppArmor配置文件库模板,允许用户强化或隔离在Linux内核上运行的基于ROS的进程。

网络安全正迅速成为机器人技术的普遍问题,尤其是随着机器人在社会中的普及越来越普遍。随着工业自动化,自动驾驶汽车,商业监控平台,家庭服务机器人以及许多其他机器人领域的出现,这些子系统的安全性应被视为至关重要,因为它们都为网络威胁提供了载体,可将其表现为现实世界中的风险。即使没有工业强度的机器人手臂或高速无人驾驶半卡车带来的危害,与智能手机和PC一样,承诺与物联网集成的个人机器人也可能成为侵犯隐私和身份盗窃来源的目标。

1. 安装    2. 教程    3. 概念    4. 命令行工具    5. 环境变量

ROS2:https://github.com/ros2/sros2/blob/master/SROS2_Linux.md

软件包提供了在DDS-Security之上使用ROS2的工具和说明。支持跨平台(Linux,macOS和Windows)以及跨不同语言(C++和Python),并都测试安全功能。

尽管正在设计SROS2支持任何一款安全的中间件,但目前正在仅支持RTI Connext Secure 5.3.1和eProsima的Fast-RTPS 1.6.0,并进行测试。如果要使用RTI Connext Secure运行演示,则需要许可证并需要安装。

  • 在Linux上使用SROS2
  • 在MacOS上使用SROS2
  • 在Windows上使用SROS2

这里,以ROS2网络中使用SROS2为例简要说明,网络消息安全性对多机器人系统非常重要。

dashing可以直接用功能包安装:

sudo apt install ros-dashing-sros2

创建秘钥仓库:

ros2 security create_keystore xxx_keys

创建节点:

ros2 security create_key xxx_keys /talker
ros2 security create_key xxx_keys /listener

We use minimal_publisher and minimal_subscriber here.

mr_keys(multi-robots)

配置环境变量:

export ROS_SECURITY_ROOT_DIRECTORY=xxx_keys
export ROS_SECURITY_ENABLE=true
export ROS_SECURITY_STRATEGY=Enforce

网络使用需要将秘钥复制到对应网络设备中。

scp -r talker USERNAME@xxx:~/xxx_keys

否则无法收到加密消息,虽然能看到节点和主题,但是没有任何更新和显示。

节点和主题
无法收到消息
security pub
security sub

 


 

这篇关于ROS2网络多机通信DDS和安全加密SROS(多机器人系统)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/852177

相关文章

Debian 13升级后网络转发等功能异常怎么办? 并非错误而是管理机制变更

《Debian13升级后网络转发等功能异常怎么办?并非错误而是管理机制变更》很多朋友反馈,更新到Debian13后网络转发等功能异常,这并非BUG而是Debian13Trixie调整... 日前 Debian 13 Trixie 发布后已经有众多网友升级到新版本,只不过升级后发现某些功能存在异常,例如网络转

JWT + 拦截器实现无状态登录系统

《JWT+拦截器实现无状态登录系统》JWT(JSONWebToken)提供了一种无状态的解决方案:用户登录后,服务器返回一个Token,后续请求携带该Token即可完成身份验证,无需服务器存储会话... 目录✅ 引言 一、JWT 是什么? 二、技术选型 三、项目结构 四、核心代码实现4.1 添加依赖(pom

基于Python实现自动化邮件发送系统的完整指南

《基于Python实现自动化邮件发送系统的完整指南》在现代软件开发和自动化流程中,邮件通知是一个常见且实用的功能,无论是用于发送报告、告警信息还是用户提醒,通过Python实现自动化的邮件发送功能都能... 目录一、前言:二、项目概述三、配置文件 `.env` 解析四、代码结构解析1. 导入模块2. 加载环

linux系统上安装JDK8全过程

《linux系统上安装JDK8全过程》文章介绍安装JDK的必要性及Linux下JDK8的安装步骤,包括卸载旧版本、下载解压、配置环境变量等,强调开发需JDK,运行可选JRE,现JDK已集成JRE... 目录为什么要安装jdk?1.查看linux系统是否有自带的jdk:2.下载jdk压缩包2.解压3.配置环境

Python开发简易网络服务器的示例详解(新手入门)

《Python开发简易网络服务器的示例详解(新手入门)》网络服务器是互联网基础设施的核心组件,它本质上是一个持续运行的程序,负责监听特定端口,本文将使用Python开发一个简单的网络服务器,感兴趣的小... 目录网络服务器基础概念python内置服务器模块1. HTTP服务器模块2. Socket服务器模块

Linux查询服务器系统版本号的多种方法

《Linux查询服务器系统版本号的多种方法》在Linux系统管理和维护工作中,了解当前操作系统的版本信息是最基础也是最重要的操作之一,系统版本不仅关系到软件兼容性、安全更新策略,还直接影响到故障排查和... 目录一、引言:系统版本查询的重要性二、基础命令解析:cat /etc/Centos-release详

Go语言网络故障诊断与调试技巧

《Go语言网络故障诊断与调试技巧》在分布式系统和微服务架构的浪潮中,网络编程成为系统性能和可靠性的核心支柱,从高并发的API服务到实时通信应用,网络的稳定性直接影响用户体验,本文面向熟悉Go基本语法和... 目录1. 引言2. Go 语言网络编程的优势与特色2.1 简洁高效的标准库2.2 强大的并发模型2.

更改linux系统的默认Python版本方式

《更改linux系统的默认Python版本方式》通过删除原Python软链接并创建指向python3.6的新链接,可切换系统默认Python版本,需注意版本冲突、环境混乱及维护问题,建议使用pyenv... 目录更改系统的默认python版本软链接软链接的特点创建软链接的命令使用场景注意事项总结更改系统的默

在Linux系统上连接GitHub的方法步骤(适用2025年)

《在Linux系统上连接GitHub的方法步骤(适用2025年)》在2025年,使用Linux系统连接GitHub的推荐方式是通过SSH(SecureShell)协议进行身份验证,这种方式不仅安全,还... 目录步骤一:检查并安装 Git步骤二:生成 SSH 密钥步骤三:将 SSH 公钥添加到 github

Linux系统中查询JDK安装目录的几种常用方法

《Linux系统中查询JDK安装目录的几种常用方法》:本文主要介绍Linux系统中查询JDK安装目录的几种常用方法,方法分别是通过update-alternatives、Java命令、环境变量及目... 目录方法 1:通过update-alternatives查询(推荐)方法 2:检查所有已安装的 JDK方