news 2026/4/23 11:45:15

ros2(jazzy)多节点运行在同一个进程范例(对标ros1的nodelet)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
ros2(jazzy)多节点运行在同一个进程范例(对标ros1的nodelet)

以下是一个完整的ROS2 节点动态组合(Composable Nodes)开发案例,涵盖编译时组合运行时组合两种方式,并包含参数传递命名空间重映射等高级功能。


案例目标

  • 实现一个Talker(发布者)Listener(订阅者)节点,并动态组合到单个进程中。
  • 支持编译时组合(硬编码)和运行时组合(通过component_container动态加载)。
  • 演示参数传递命名空间重映射

1. 创建 ROS2 包

mkdir-p ~/ros2_ws/srccd~/ros2_ws/src ros2 pkg create composition_demo --build-type ament_cmake --dependencies rclcpp rclcpp_components

2. 编写 Talker 和 Listener 组件

(1) Talker 组件 (talker_component.cpp)

#include"rclcpp/rclcpp.hpp"#include"rclcpp_components/register_node_macro.hpp"#include"std_msgs/msg/string.hpp"classTalker:publicrclcpp::Node{public:Talker(constrclcpp::NodeOptions&options):Node("talker",options){publisher_=this->create_publisher<std_msgs::msg::String>("chatter",10);timer_=this->create_wall_timer(std::chrono::milliseconds(500),std::bind(&Talker::publish_message,this));}private:voidpublish_message(){automsg=std_msgs::msg::String();msg.data="Hello, ROS2 Composition!";publisher_->publish(msg);RCLCPP_INFO(this->get_logger(),"Published: '%s'",msg.data.c_str());}rclcpp::Publisher<std_msgs::msg::String>::SharedPtr publisher_;rclcpp::TimerBase::SharedPtr timer_;};RCLCPP_COMPONENTS_REGISTER_NODE(Talker)// 注册为组件

(2) Listener 组件 (listener_component.cpp)

#include"rclcpp/rclcpp.hpp"#include"rclcpp_components/register_node_macro.hpp"#include"std_msgs/msg/string.hpp"classListener:publicrclcpp::Node{public:Listener(constrclcpp::NodeOptions&options):Node("listener",options){subscription_=this->create_subscription<std_msgs::msg::String>("chatter",10,std::bind(&Listener::listen_message,this,std::placeholders::_1));}private:voidlisten_message(conststd_msgs::msg::String::SharedPtr msg){RCLCPP_INFO(this->get_logger(),"Received: '%s'",msg->data.c_str());}rclcpp::Subscription<std_msgs::msg::String>::SharedPtr subscription_;};RCLCPP_COMPONENTS_REGISTER_NODE(Listener)// 注册为组件

3. 编译时组合(Hardcoded Composition)

(1) 创建manual_composition.cpp

#include"rclcpp/rclcpp.hpp"#include"talker_component.hpp"#include"listener_component.hpp"intmain(intargc,char**argv){rclcpp::init(argc,argv);// 创建多线程执行器rclcpp::executors::MultiThreadedExecutor executor;// 手动创建 Talker 和 Listener 节点autotalker=std::make_shared<Talker>(rclcpp::NodeOptions());autolistener=std::make_shared<Listener>(rclcpp::NodeOptions());// 添加到执行器executor.add_node(talker);executor.add_node(listener);// 运行执行器executor.spin();rclcpp::shutdown();return0;}

(2) 修改CMakeLists.txt

cmake_minimum_required(VERSION 3.8) project(composition_demo) find_package(ament_cmake REQUIRED) find_package(rclcpp REQUIRED) find_package(rclcpp_components REQUIRED) find_package(std_msgs REQUIRED) # 组件库 add_library(talker_component SHARED src/talker_component.cpp) ament_target_dependencies(talker_component rclcpp rclcpp_components std_msgs) target_compile_definitions(talker_component PRIVATE "COMPOSITION_BUILDING_DLL") add_library(listener_component SHARED src/listener_component.cpp) ament_target_dependencies(listener_component rclcpp rclcpp_components std_msgs) target_compile_definitions(listener_component PRIVATE "COMPOSITION_BUILDING_DLL") # 编译时组合 add_executable(manual_composition src/manual_composition.cpp) ament_target_dependencies(manual_composition rclcpp rclcpp_components std_msgs) target_link_libraries(manual_composition talker_component listener_component) # 安装 install(TARGETS talker_component listener_component manual_composition DESTINATION lib/${PROJECT_NAME} ) ament_package()

(3) 编译并运行

cd~/ros2_ws colcon build --packages-select composition_demosourceinstall/setup.bash ros2 run composition_demo manual_composition

输出

[INFO] [talker]: Published: 'Hello, ROS2 Composition!' [INFO] [listener]: Received: 'Hello, ROS2 Composition!'

4. 运行时组合(Dynamic Composition)

(1) 启动component_container

ros2 run rclcpp_components component_container

(2) 动态加载 Talker 和 Listener

# 加载 Talkerros2 component load /ComponentManager composition_demo composition_demo::Talker# 加载 Listenerros2 component load /ComponentManager composition_demo composition_demo::Listener

输出

[INFO] [talker]: Published: 'Hello, ROS2 Composition!' [INFO] [listener]: Received: 'Hello, ROS2 Composition!'

(3) 查看已加载组件

ros2 component list

输出

/ComponentManager 1 /talker 2 /listener

(4) 卸载组件

ros2 component unload /ComponentManager12

输出

Unloaded component 1 from '/ComponentManager' container Unloaded component 2 from '/ComponentManager' container

5. 高级功能

(1) 参数传递

ros2 component load /ComponentManager composition_demo composition_demo::Talker -p use_sim_time:=true

(2) 命名空间重映射

ros2 component load /ComponentManager composition_demo composition_demo::Listener --node-namespace /my_ns

(3) 使用dlopen动态加载

ros2 run composition_demo dlopen_composition\$(ros2 pkg prefix composition_demo)/lib/libtalker_component.so\$(ros2 pkg prefix composition_demo)/lib/liblistener_component.so

6. 总结

方式特点适用场景
编译时组合硬编码,所有节点在同一个进程固定节点组合,高性能
运行时组合动态加载,灵活管理需要动态调整节点
dlopen组合直接加载.so文件无 ROS 接口依赖
Launch 文件组合自动化启动复杂系统部署

完整代码:GitHub - ROS2 Composition Demo


通过这个案例,你可以:

  1. 理解 ROS2 组件化开发(Composable Nodes)。
  2. 掌握编译时和运行时组合的方式。
  3. 学会参数传递和命名空间重映射
  4. 应用于多传感器融合、自主导航等复杂系统
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/18 15:37:17

腾讯开源翻译模型应用:旅游行业多语言导览

腾讯开源翻译模型应用&#xff1a;旅游行业多语言导览 随着全球化进程加速&#xff0c;旅游行业对高质量、低延迟的多语言导览需求日益增长。传统翻译服务往往依赖云端API&#xff0c;存在网络延迟高、数据隐私风险大、离线场景不可用等问题。为应对这一挑战&#xff0c;腾讯近…

作者头像 李华
网站建设 2026/4/15 17:36:30

HY-MT1.5边缘计算方案:离线环境翻译应用部署

HY-MT1.5边缘计算方案&#xff1a;离线环境翻译应用部署 在多语言交流日益频繁的今天&#xff0c;高质量、低延迟的翻译服务成为智能设备、跨境沟通和本地化应用的核心需求。然而&#xff0c;依赖云端API的传统翻译方案面临网络延迟、数据隐私和离线不可用等挑战。为此&#x…

作者头像 李华
网站建设 2026/4/18 7:34:13

PDF-Extract-Kit部署教程:跨平台部署解决方案

PDF-Extract-Kit部署教程&#xff1a;跨平台部署解决方案 1. 引言 1.1 技术背景与学习目标 PDF-Extract-Kit 是一款由开发者“科哥”二次开发构建的PDF智能提取工具箱&#xff0c;集成了布局检测、公式识别、OCR文字提取、表格解析等核心功能&#xff0c;广泛适用于学术论文…

作者头像 李华
网站建设 2026/4/12 19:34:01

Keil5目标选项配置核心要点:Target设置通俗解释

Keil5的“Target”设置&#xff0c;到底该怎么配&#xff1f;—— 从时钟到内存的真实作用揭秘 你有没有遇到过这样的情况&#xff1a;代码编译通过、下载成功&#xff0c;但单片机就是不跑&#xff1f;或者FreeRTOS调度慢得像卡顿视频&#xff1f;又或者DMA传输莫名其妙出错&a…

作者头像 李华
网站建设 2026/4/19 18:12:35

混元1.5翻译模型:术语干预功能实现代码示例

混元1.5翻译模型&#xff1a;术语干预功能实现代码示例 1. 引言 随着全球化进程的加速&#xff0c;高质量、可定制化的机器翻译需求日益增长。传统翻译模型在面对专业术语、混合语言或特定上下文场景时&#xff0c;往往难以保证一致性与准确性。为解决这一问题&#xff0c;腾…

作者头像 李华
网站建设 2026/4/18 12:44:25

HY-MT1.5翻译模型实战:术语干预功能使用教程

HY-MT1.5翻译模型实战&#xff1a;术语干预功能使用教程 随着多语言交流需求的不断增长&#xff0c;高质量、可定制化的机器翻译模型成为跨语言应用的核心支撑。腾讯开源的混元翻译模型HY-MT1.5系列&#xff0c;凭借其卓越的翻译性能和创新的功能设计&#xff0c;迅速在开发者…

作者头像 李华