1. OpenClaw 为什么值得接到 ROS 2 上
OpenClaw 之所以突然爆火,不只是因为它能聊天,而是因为它把大模型从“会回答问题”往“会调工具、会调用外部系统”推了一步。对机器人开发来说,这一点很关键。ROS 2 负责节点通信、状态管理和控制接口,让机器人硬件有了标准化的“执行神经”;OpenClaw则可以看成装在这套神经前面的“语言大脑”,把人说的话翻译成可以落地的系统操作。两者一结合,机器人就不再只能靠按钮、脚本或者固定界面控制,而是可以开始接收自然语言指令。
这篇文章做的事情很具体:把 OpenClaw 接到一个基于 ROS 2 的串口机械夹爪项目上,跑通一条最小闭环,让自然语言真正落到舵机动作上,并且能通过状态反馈确认控制是否生效。
OpenClaw -> RosClaw -> rosbridge -> ROS 2 -> 串口桥节点 -> STM32 -> 舵机夹爪
整套系统最终能完成的动作也很直接:打开夹爪、闭合夹爪、调整到指定角度、查询当前角度状态。
换句话说,这篇文章不是在讲一个抽象概念,而是在讲怎么把 OpenClaw 和 ROS 2 真正接起来,让聊天式控制变成一条工程链路。
2. 整体架构
这套方案的本质,并不是“让大模型直接控制舵机”,而是把控制分成了几层,每一层只负责自己该做的事。
在当前项目中,最关键的 ROS 2 接口有三个:
·/servo/command:发布serial_servo_bridge/msg/ServoCommand
·/servo/status:读取serial_servo_bridge/msg/ServoStatus
·/servo/status_raw:查看原始串口回传
这一点决定了后面Skill、工具层和排错方法的写法。只要这三个接口定义清楚,系统就有一个稳定的控制边界。
3. 环境准备
本文默认环境如下:
·Ubuntu 22.04
·ROS 2 Humble
需要的软件组件包括:
·openclaw
·rosbridge_server
·本项目中的serial_servo(每个人与舵机的串口通信功能包都不一样,这里提供一个自己的功能包)
安装 serial_servo:
https://github.com/COONEO/Openclaw_To_ROS2
安装OpenClaw:
npm install -g openclaw@latestopenclaw onboard --install-daemon
安装详情请看:https://openclaws.io/zh/
安装后可确认版本:
openclaw--version
安装 RosClaw 本体包:
git clone https://github.com/PlaiPin/rosclaw.git
rosclaw是一个pnpmworkspace,安装插件依赖前要先准备好pnpm。如果系统里还没有pnpm,可以直接用npm安装即可:
npm install -g pnpm@9.15.4pnpm-v
安装 RosClaw 插件:
cd /home/kuniu/rosclawpnpm installopenclaw plugins install -l /home/kuniu/rosclaw/extensions/openclaw-pluginopenclaw plugins enable rosclawopenclaw gateway restart
安装rosbridge_server:
sudo apt install ros-humble-rosbridge-server
如果串口设备需要权限:
sudo usermod -aG dialout $USER
重新登录后权限才会生效。
4. 跑通原始 ROS 2 夹爪链路
这是整篇教程里最关键的一步。
不要一上来就调OpenClaw。先证明一件事:在不用 OpenClaw 的前提下,这个夹爪本身就能被 ROS 2 正常控制。
先构建工作空间:
cd /home/kuniu/serial_servocolcon build source install/setup.bash
启动串口通信(启动前务必检查单片机是否通过串口连接上了电脑):
ros2 launch serial_servo_bridge serial_servo_bridge.launch.py
然后手动发布一条角度指令:
ros2 topic pub --once /servo/command serial_servo_bridge/msg/ServoCommand "{mode: 0, servo_id: 1, value: -30.0}"
这里与舵机串口通信的发送格式是AT+Pos,<servo_id>,<angle>\n接收格式是AT+Angle,<servo_id>,<angle>\n你可以根据自身情况对舵机的通信协议进行调整
预期现象:
·机械夹爪有明确动作
可以直接观察状态:
ros2 topic echo /servo/status
5. 接入 OpenClaw 和 RosClaw
当原始 ROS 2 链路确认正常以后,再让 OpenClaw 进来。
先检查 OpenClaw 网关状态:
openclaw gateway status
再确认 RosClaw 插件已经安装并启用:
openclaw plugins list
如果列表里没有rosclaw,先回到前面的安装步骤;如果已经有rosclaw,下一步就不是“再装一遍”,而是把它的传输方式明确设成rosbridge。
本文使用的是rosbridge接入模式,因此~/.openclaw/openclaw.json里需要有对应配置。直接用命令写进去:
openclaw config set plugins.entries.rosclaw.config '{"transport":{"mode":"rosbridge"},"rosbridge":{"url":"ws://127.0.0.1:9090"},"robot":{"name":"serial-gripper","namespace":""}}'openclaw config get plugins.entries.rosclawopenclaw gateway restart
如果你更习惯直接看文件,也可以打开:
openclaw config filesed-n'1,120p' ~/.openclaw/openclaw.json
正常情况下,rosclaw这一段会接近下面这样:
{"plugins":{ "entries":{ "rosclaw":{ "enabled":true, "config":{ "transport":{ "mode":"rosbridge" }, "rosbridge":{ "url":"ws://127.0.0.1:9090" }, "robot":{ "name":"serial-gripper", "namespace":"" } } } } }}
走到这里,还不能直接测“打开夹爪”。因为 OpenClaw 现在只是知道“系统里有个 RosClaw 插件”,它还不知道你这个夹爪该怎么理解中文指令。这个约束需要 Skill 来补。
本文对 RosClaw 的本地修改说明
这里需要单独说明一下:本文使用的rosclaw不是完全原版,而是在本地做了 3 处小修改。这些修改不大,但会明显影响“自然语言控制夹爪”这件事的稳定性。
涉及的文件是:
·ros2-publish.ts
·ros2-action.ts
·topics.ts
这 3 处修改主要做了几件事:
·ros2_publish会自动补全 topic 前导/
·发布/servo/command前会先advertise
·对serial_servo_bridge/msg/ServoCommand做了额外容错,避免模型把消息错误写成command/angle
·ros2_action_goal会先检查目标是不是真正的action,避免把/servo/command这种 topic 错当 action 去调
应用 RosClaw 本地补丁
本文使用的补丁文件已经放在serial_servo包里,直接在rosclaw仓库根目录执行下面这组命令即可:
cd /home/kuniu/rosclawgit apply /home/kuniu/serial_servo/rosclaw_local.patchpnpm installopenclaw gateway restart
如果git apply没有任何输出,也没有报错,通常就说明补丁已经正确打进去了。
6. 启动 rosbridge 和夹爪节点
打开新终端启动rosbridge_server启动时,必须先加载 ROS 2 工作空间环境。正确方式如下:
source /opt/ros/humble/setup.bashsource /home/kuniu/serial_servo/install/setup.bashros2 launch rosbridge_server rosbridge_websocket_launch.xml
启动完rosbridge以后,先不要急着打开OpenClaw。建议再做一个检查,确认rosbridge确实认识你的自定义消息:
source /opt/ros/humble/setup.bashsource /home/kuniu/serial_servo/install/setup.bashros2 service call /rosapi/message_details rosapi_msgs/srv/MessageDetails '{type: serial_servo_bridge/msg/ServoCommand}'
如果返回里能看到mode、servo_id、value这些字段,说明rosbridge这一层基本正常;如果这里查不到定义,后面 OpenClaw 多半会出现“显示成功但实际上没发出去”的假象。
再另开一个终端处理 OpenClaw 侧的Skill。很多人第一次做这类控制,都会自然地想,既然模型能理解中文,那直接让它自己调用 ROS 2 工具不就行了。实际很快就会发现,这种想法在硬件控制场景里并不稳,因为模型会猜。它可能猜错该用topic还是action,猜错消息字段该叫什么,也可能直接回复“已调整到位”。这些问题在普通聊天里影响不大,放到机械夹爪这种真实执行机构上,就是明确的工程风险。所以这里必须用 Skill 把模型的自由发挥空间收紧。
先创建 Skill 目录:
mkdir-p ~/.openclaw/skills/gripper-control
然后把包内提供的SKILL.md复制过去,这份 skill 已经按当前夹爪的真实语义写好了,你们也可以按自己的需求新增或修改skill:
·SKILL.md
cp /home/kuniu/serial_servo/openclaw_skills/gripper-control/SKILL.md \ ~/.openclaw/skills/gripper-control/SKILL.md
写完以后执行:
openclaw skills listopenclaw gateway restartopenclaw dashboard
你应该能在skills list里看到gripper-control,状态通常会是ready。如果你之前已经开着一个旧会话,建议新建一个会话再测,因为旧会话不一定会立刻拿到新的 Skill 快照。
7. 实际测试流程
测试1:明确调用 ROS 2 工具
先在 OpenClaw 官方页面里输入一条非常明确的命令:
用 ros2_publish 向 /servo/command 发布serial_servo_bridge/msg/ServoCommand,消息为 {mode: 0, servo_id: 1, value: -30.0}
预期结果应该看到夹爪张开了大约三十度的角度,如果这一步都不通,说明问题还停留在工具层或 rosbridge 层。
测试2:自然语言打开夹爪
打开夹爪
预期结果:
·OpenClaw 触发gripper-control
·ROS 2 发布/servo/command
·夹爪张开
测试3:自然语言设置指定角度
把夹爪调到 -20 度
预期结果:
·发布正确的/servo/command
·随后读取/servo/status
测试4:查询当前状态
当前夹爪角度是多少
预期结果:
·调用ros2_subscribe_once
·读取/servo/status
·返回当前真实硬件角度,而不是凭空生成一个答案
8. 后续怎么扩展
如果这篇教程对应的最小闭环已经稳定跑通,后面可以继续沿三个方向扩展。
第一,进一步收紧控制接口。比如把当前直接 topic 控制继续封装成 ROS 2 service 或action,减少模型自己拼消息的空间。
第二,补上复杂动作执行层。例如实现“按节奏开合”“点头”“摇摆”等预定义动作,让 OpenClaw 负责选择动作和传参数。
第三,迁移到其他机器人。同样的整体思路可以迁移到导航小车、机械臂或移动操作平台,只是具体的topic、消息类型和控制器会不同。
9. 小结
回头看这套复现过程,真正关键的不是“让大模型学会控制硬件”,而是把整条链路的边界分清楚。
这套方案之所以最后能稳定下来,本质上依赖四件事:
·Skill 意图
·工具层调用格式
·ROS 2 节点执行硬件控制
·状态反馈确认执行结果
OpenClaw的落地,并非机器人智能控制的终点,而是一个全新的起点。未来,我们还将继续深耕与ROS2生态的深度融合,持续优化自然语言的细节解析能力,拓展更多精细化的动作执行场景,同时也将坚持开源开放的理念,与广大机器人开发者一起,丰富OpenClaw的生态,让机器人的智能交互,真正走进更多开发与应用场景中。
COONEO酷牛由荷兰瓦赫宁根大学(农业、食品领域世界排名第一,发起/主导多个欧盟智慧农业及农业机器人项目)博士创立,致力于让机器人研发更高效以及将先进的AI、IoT、机器人等技术应用于智慧农业、生态环保等领域。进而实现农业生产效率的提升,以应对全球人口增长与粮食危机以及农业劳动力锐减的问题。为生产充足、健康、美味的粮食提供科技支持。
公司获邀加入由NVIDIA发起的“英伟达初创加速计划NVIDIA Inception”,该计划旨在培养颠覆行业格局的优秀AI初创公司。 团队荣获首届睿抗(杨凌)全球农业机器人应用赛产业之星奖。 公司产品在中国杨凌农业高新科技成果博览会“四新”成果发布上认定为优秀农业成果新产品。 团队在中国(深圳)海归创业大会上,从全球征集的117个海归创业项目中入围最终路演的10个项目并获得“最具人气奖”。 团队荣获深圳留创园最具市场潜力奖 团队从700多家人工智能企业中脱颖而出,加入央视《赢在AI+》未来营。 荣获BEYOND INNOVATION AWARDS 2025 荣获未来农业新星企业奖


夜雨聆风