一、简介:为什么实时 Linux 选型对 ROS/ROS 2 至关重要?

  • 背景:ROS(Robot Operating System)和 ROS 2 是机器人开发的核心框架,广泛应用于工业自动化、自动驾驶、服务机器人等领域。实时性是这些应用的关键需求,因为机器人需要在精确的时间内响应环境变化,以确保安全和效率。

  • 重要性:实时 Linux 是实现机器人实时性的关键。PREEMPT_RT 是一种流行的实时补丁,它通过减少 Linux 内核的中断延迟,提高了系统的实时性能。然而,市场上还有其他实时操作系统(RTOS)如 Xenomai 和 RT-Linux,它们在某些场景下可能更适合特定的 ROS/ROS 2 应用。

  • 应用场景:在工业机器人中,实时性要求极高,例如机械臂的精确控制需要在毫秒级响应。在自动驾驶中,车辆的传感器数据处理和决策需要实时完成,以避免碰撞。掌握实时 Linux 的选型技能,可以帮助开发者选择最适合其应用的实时解决方案,从而提高系统的可靠性和性能。


二、核心概念:实时 Linux 的基本概念和术语

2.1 实时任务的特性

  • 实时性:任务必须在规定的时间内完成,否则可能导致系统故障。

  • 周期性:任务通常以固定周期运行,例如传感器数据采集。

  • 优先级:高优先级任务可以抢占低优先级任务,确保关键任务优先执行。

2.2 相关协议和工具

  • PREEMPT_RT:一种实时补丁,通过减少内核中断延迟来提高实时性。

  • Xenomai:一种实时操作系统,提供硬实时支持,适用于对实时性要求极高的场景。

  • RT-Linux:另一种实时操作系统,提供硬实时支持,与 Xenomai 类似。

  • ROS/ROS 2:机器人操作系统,提供高级抽象和通信机制,简化机器人开发。


三、环境准备:搭建测试环境

3.1 硬件环境

  • CPU:多核处理器(≥4 核)

  • 内存:至少 8 GB RAM

  • 存储:SSD 硬盘

3.2 软件环境

组件 版本 安装命令
Ubuntu Server 20.04 sudo apt update && sudo apt upgrade -y
ROS Noetic 1.15.14 sudo apt install ros-noetic-desktop-full
ROS 2 Foxy 1.1.0 sudo apt install ros-foxy-desktop
PREEMPT_RT 内核 5.15.71-rt53 见下文一键脚本

3.3 安装 PREEMPT_RT 内核

#!/bin/bash
# install_rt_kernel.sh
set -e
VERSION=5.15.71
RT_PATCH=patch-5.15.71-rt53.patch.xz
wget https://cdn.kernel.org/pub/linux/kernel/v5.x/linux-${VERSION}.tar.xz
wget https://cdn.kernel.org/pub/linux/kernel/projects/rt/${VERSION}/${RT_PATCH}
tar -xf linux-${VERSION}.tar.xz
cd linux-${VERSION}
xzcat ../${RT_PATCH} | patch -p1
make olddefconfig
./scripts/config --set-val CONFIG_PREEMPT_RT y
make -j$(nproc) deb-pkg
sudo dpkg -i ../linux-*.deb

重启后选择 RT 内核进入即可。


四、应用场景:工业机器人实时控制

在工业机器人中,实时性要求极高。机械臂的精确控制需要在毫秒级响应,以确保生产效率和安全性。例如,一个机械臂需要在 1 ms 内完成位置更新,任何延迟都可能导致生产事故。通过使用 PREEMPT_RT 补丁,可以显著降低内核中断延迟,确保机械臂的实时控制。


五、实际案例与步骤:评估 PREEMPT_RT 与 ROS/ROS 2 的兼容性

5.1 安装 ROS Noetic 和 ROS 2 Foxy

# 安装 ROS Noetic
sudo apt update && sudo apt install ros-noetic-desktop-full
source /opt/ros/noetic/setup.bash

# 安装 ROS 2 Foxy
sudo apt update && sudo apt install ros-foxy-desktop
source /opt/ros/foxy/setup.bash

5.2 创建 ROS Noetic 工作空间

mkdir -p ~/ros_noetic_ws/src
cd ~/ros_noetic_ws/
catkin_make
source devel/setup.bash

5.3 创建 ROS 2 Foxy 工作空间

mkdir -p ~/ros2_foxy_ws/src
cd ~/ros2_foxy_ws/
ros2 pkg create --build-type ament_cmake my_robot
cd my_robot

5.4 编写实时任务代码

5.4.1 ROS Noetic 实时任务示例
// ~/ros_noetic_ws/src/my_robot/src/realtime_task.cpp
#include <ros/ros.h>
#include <std_msgs/String.h>

void realtime_task() {
    ros::NodeHandle nh;
    ros::Publisher pub = nh.advertise<std_msgs::String>("realtime_topic", 1000);
    ros::Rate rate(1000); // 1 kHz

    while (ros::ok()) {
        std_msgs::String msg;
        msg.data = "Realtime message";
        pub.publish(msg);
        rate.sleep();
    }
}

int main(int argc, char **argv) {
    ros::init(argc, argv, "realtime_task");
    realtime_task();
    return 0;
}
5.4.2 ROS 2 Foxy 实时任务示例
// ~/ros2_foxy_ws/src/my_robot/src/realtime_task.cpp
#include <rclcpp/rclcpp.hpp>
#include <std_msgs/msg/string.hpp>

void realtime_task() {
    rclcpp::Node::SharedPtr node = rclcpp::Node::make_shared("realtime_task");
    rclcpp::Publisher<std_msgs::msg::String>::SharedPtr pub = node->create_publisher<std_msgs::msg::String>("realtime_topic", 1000);
    rclcpp::Rate rate(1000); // 1 kHz

    while (rclcpp::ok()) {
        std_msgs::msg::String msg;
        msg.data = "Realtime message";
        pub->publish(msg);
        rate.sleep();
    }
}

int main(int argc, char **argv) {
    rclcpp::init(argc, argv);
    realtime_task();
    rclcpp::shutdown();
    return 0;
}

5.5 编译和运行

5.5.1 编译 ROS Noetic 工作空间
cd ~/ros_noetic_ws/
catkin_make
source devel/setup.bash
5.5.2 编译 ROS 2 Foxy 工作空间
cd ~/ros2_foxy_ws/
colcon build
source install/setup.bash
5.5.3 运行实时任务
# ROS Noetic
rosrun my_robot realtime_task

# ROS 2 Foxy
ros2 run my_robot realtime_task

5.6 测试实时性能

使用 cyclictest 测试实时性能:

sudo apt install rt-tests
cyclictest -p99 -i100 -d60s -n > cyclictest.log

结果解读:

T: 0 ( 1234) P:99 I:100 C: 600000 Min:  8 Act:  12 Avg:  14 Max:  38

Max=38 μs < 50 μs → 满足实时性要求。


六、常见问题与解答(FAQ)

问题 现象 解决
cyclictest Max 延迟 > 50 μs 未关超线程/电源管理 BIOS 关闭 Turbo、C-State,内核加 nohz_full
ROS Noetic 与 ROS 2 同时安装冲突 包冲突 分别安装在不同工作空间,确保 source 正确
实时任务响应延迟 任务优先级设置过低

调整任务优先级,确保高优先级任务优先执行 | | PREEMPT_RT 内核不稳定 | 内核版本不匹配 | 确保内核版本与补丁版本一致 |


七、实践建议与最佳实践

  1. 实时任务优先级设置
    确保实时任务的优先级高于普通任务,以保证关键任务优先执行。

  2. 内核参数优化
    使用 sysctl 调整内核参数,如 vm.swappinessnet.core.somaxconn,以提高系统性能。

  3. 测试与验证
    使用 cyclictestpip_stress 等工具定期测试实时性能,确保系统满足实时性要求。

  4. 文档化
    记录实时任务的配置和测试结果,便于后续维护和优化。

  5. 社区支持
    参与 ROS 和 PREEMPT_RT 社区,获取最新信息和技术支持。


八、总结与应用场景:回顾要点,强调实战必要性

通过本文,你已经了解了 PREEMPT_RT 补丁与 ROS/ROS 2 的兼容性,并掌握了如何在实时 Linux 系统中实现 ROS/ROS 2 应用的实时性。实时 Linux 是实现机器人实时性的关键,通过选择合适的实时解决方案,可以显著提高系统的可靠性和性能。

在实际应用中,例如工业机器人控制和自动驾驶,实时性是确保安全和效率的核心需求。通过使用 PREEMPT_RT 补丁,可以显著降低内核中断延迟,确保实时任务的及时执行。希望你将所学知识应用到真实项目中,提升你的机器人应用开发能力。

Logo

DAMO开发者矩阵,由阿里巴巴达摩院和中国互联网协会联合发起,致力于探讨最前沿的技术趋势与应用成果,搭建高质量的交流与分享平台,推动技术创新与产业应用链接,围绕“人工智能与新型计算”构建开放共享的开发者生态。

更多推荐