远程 OpenClaw(macOS ⇄ 远程主机)
此流程让 macOS 应用充当在另一台主机(桌面/服务器)上运行的 OpenClaw gateway 的完全远程控制。这是应用的 Remote over SSH(远程运行)功能。所有功能——健康检查、Voice Wake 转发和 Web Chat——都重用来自 设置 → General 的相同远程 SSH 配置。
模式
- Local (this Mac):所有内容都在笔记本电脑上运行。不涉及 SSH。
- Remote over SSH(默认):OpenClaw 命令在远程主机上执行。mac 应用使用 -o BatchMode 加上你选择的 identity/key 和本地端口转发打开 SSH 连接。
- Remote direct (ws/wss):无 SSH 隧道。mac 应用直接连接到 gateway URL(例如,通过 Tailscale Serve 或公共 HTTPS 反向代理)。
远程传输
远程模式支持两种传输:
- SSH tunnel(默认):使用 ssh -N -L ... 将 gateway 端口转发到 localhost。由于隧道是回环的,gateway 将看到节点的 IP 为 127.0.0.1。
- Direct (ws/wss):直接连接到 gateway URL。gateway 看到真实的客户端 IP。
远程主机上的前置要求
- 安装 Node + pnpm 并构建/安装 OpenClaw CLI(pnpm install && pnpm build && pnpm link --global)。
- 确保 openclaw 在非交互式 shell 的 PATH 上(如果需要,符号链接到 /usr/local/bin 或 /opt/homebrew/bin)。
- 使用密钥认证打开 SSH。我们推荐 Tailscale IP 以实现稳定的 LAN 外可达性。
macOS 应用设置
- 打开 设置 → General。
- 在 OpenClaw runs 下,选择 Remote over SSH 并设置:
- Transport:SSH tunnel 或 Direct (ws/wss)。
- SSH target:user@host(可选 :port)。
- 如果 gateway 在同一 LAN 上并广播 Bonjour,从发现列表中选择它以自动填充此字段。
- Gateway URL(仅 Direct):wss://gateway.example.ts.net(或 ws://... 用于本地/LAN)。
- Identity file(高级):你的密钥路径。
- Project root(高级):用于命令的远程检出路径。
- CLI path(高级):可运行 openclaw 入口点/二进制文件的可选路径(在广播时自动填充)。
- 点击 Test remote。成功表示远程 openclaw status --json 正确运行。失败通常意味着 PATH/CLI 问题;退出 127 表示远程找不到 CLI。
- 健康检查和 Web Chat 现在将自动通过此 SSH 隧道运行。
Web Chat
- SSH tunnel:Web Chat 通过转发的 WebSocket 控制端口(默认 18789)连接到 gateway。
- Direct (ws/wss):Web Chat 直接连接到配置的 gateway URL。
- 不再有单独的 WebChat HTTP 服务器。
权限
- 远程主机需要与本地相同的 TCC 批准(Automation、Accessibility、Screen Recording、Microphone、Speech Recognition、Notifications)。在该机器上运行入职以授予一次。
- 节点通过 node.list / node.describe 广播其权限状态,以便 agent 知道可用内容。
安全注意事项
- 在远程主机上首选回环绑定,并通过 SSH 或 Tailscale 连接。
- 如果你将 Gateway 绑定到非回环接口,需要 token/password 认证。
- 参见 Security 和 Tailscale。
WhatsApp 登录流程(远程)
- 在远程主机上运行 openclaw channels login --verbose。用手机上的 WhatsApp 扫描 QR。
- 如果 auth 过期,在该主机上重新运行登录。健康检查将显示链接问题。
故障排除
- 退出 127 / 未找到:openclaw 不在非登录 shell 的 PATH 上。将其添加到 /etc/paths、你的 shell rc,或符号链接到 /usr/local/bin//opt/homebrew/bin。
- 健康探测失败:检查 SSH 可达性、PATH,以及 Baileys 是否已登录(openclaw status --json)。
- Web Chat 卡住:确认 gateway 在远程主机上运行,转发的端口与 gateway WS 端口匹配;UI 需要健康的 WS 连接。
- 节点 IP 显示 127.0.0.1:使用 SSH 隧道时正常。如果你希望 gateway 看到真实客户端 IP,将 Transport 切换到 Direct (ws/wss)。
- Voice Wake:触发短语在远程模式下自动转发;不需要单独的转发器。
通知声音
使用 openclaw 和 node.invoke 从脚本中为每个通知选择声音,例如:
openclaw nodes notify --node <id> --title "Ping" --body "Remote gateway ready" --sound Glass
应用中不再有全局"默认声音"切换;调用者为每个请求选择声音(或无)。