Bonjour / mDNS 发现
OpenClaw 使用 Bonjour(mDNS / DNS‑SD)作为仅限局域网的便捷方式来发现活跃的 Gateway网关(WebSocket 端点)。这是尽力而为的机制,不能替代 SSH 或基于 Tailnet 的连接。通过 Tailscale 实现广域 Bonjour(单播 DNS‑SD)
如果节点和 Gateway网关处于不同网络,组播 mDNS 无法跨越网络边界。你可以通过切换到基于 Tailscale 的单播 DNS‑SD(“广域 Bonjour”)来保持相同的发现体验。 概要步骤:- 在 Gateway网关主机上运行 DNS 服务器(可通过 Tailnet 访问)。
- 在专用区域下为
_openclaw-gw._tcp发布 DNS‑SD 记录(示例:openclaw.internal.)。 - 配置 Tailscale 分割 DNS,使你选择的域名通过该 DNS 服务器为客户端(包括 iOS)解析。
openclaw.internal. 仅为示例。iOS/Android 节点会同时浏览 local. 和你配置的广域域名。
Gateway网关配置(推荐)
一次性 DNS 服务器设置(Gateway网关主机)
- 仅在 Gateway网关的 Tailscale 接口上监听 53 端口
- 从
~/.openclaw/dns/<domain>.db提供你选择的域名服务(示例:openclaw.internal.)
Tailscale DNS 设置
在 Tailscale 管理控制台中:- 添加指向 Gateway网关 Tailnet IP 的名称服务器(UDP/TCP 53)。
- 添加分割 DNS,使你的发现域名使用该名称服务器。
_openclaw-gw._tcp,无需组播。
Gateway网关监听器安全(推荐)
Gateway网关 WS 端口(默认18789)默认绑定到 local loopback。若需局域网/Tailnet 访问,请显式绑定并保持认证启用。
对于仅限 Tailnet 的设置:
- 在
~/.openclaw/openclaw.json中设置gateway.bind: "tailnet"。 - 重启 Gateway网关(或重启 macOS 菜单栏应用)。
广播方
只有 Gateway网关广播_openclaw-gw._tcp。
服务类型
_openclaw-gw._tcp— Gateway网关传输信标(供 macOS/iOS/Android 节点使用)。
TXT 键(非机密提示)
Gateway网关广播小型非机密提示以方便 UI 流程:role=gatewaydisplayName=<友好名称>lanHost=<主机名>.localgatewayPort=<端口>(Gateway网关 WS + HTTP)gatewayTls=1(仅在启用 TLS 时)gatewayTlsSha256=<sha256>(仅在启用 TLS 且指纹可用时)canvasPort=<端口>(仅在启用 canvas 主机时;默认18793)sshPort=<端口>(未覆盖时默认为 22)transport=gatewaycliPath=<路径>(可选;可运行的openclaw入口点的绝对路径)tailnetDns=<magicdns>(可选提示,当 Tailnet 可用时)
在 macOS 上调试
实用的内置工具:- 浏览实例:
- 解析单个实例(替换
<instance>):
在 Gateway网关日志中调试
Gateway网关会写入滚动日志文件(启动时输出为gateway log file: ...)。查找 bonjour: 行,特别是:
bonjour: advertise failed ...bonjour: ... name conflict resolved/hostname conflict resolvedbonjour: watchdog detected non-announced service ...
在 iOS 节点上调试
iOS 节点使用NWBrowser 来发现 _openclaw-gw._tcp。
要获取日志:
- 设置 → Gateway网关 → 高级 → 发现调试日志
- 设置 → Gateway网关 → 高级 → 发现日志 → 复现问题 → 复制
常见故障模式
- Bonjour 无法跨网络:请使用 Tailnet 或 SSH。
- 组播被阻止:某些 Wi‑Fi 网络会禁用 mDNS。
- 睡眠 / 接口变动:macOS 可能会临时丢失 mDNS 结果;请重试。
- 浏览正常但解析失败:保持机器名称简单(避免使用表情符号或标点符号),然后重启 Gateway网关。服务实例名称来源于主机名,因此过于复杂的名称可能会导致某些解析器混淆。
转义的实例名称(\032)
Bonjour/DNS‑SD 经常将服务实例名称中的字节转义为十进制 \DDD 序列(例如空格变为 \032)。
- 这在协议层面是正常的。
- UI 应进行解码后再显示(iOS 使用
BonjourEscapes.decode)。
禁用 / 配置
OPENCLAW_DISABLE_BONJOUR=1禁用广播(旧版:OPENCLAW_DISABLE_BONJOUR)。~/.openclaw/openclaw.json中的gateway.bind控制 Gateway网关绑定模式。OPENCLAW_SSH_PORT覆盖 TXT 中广播的 SSH 端口(旧版:OPENCLAW_SSH_PORT)。OPENCLAW_TAILNET_DNS在 TXT 中发布 MagicDNS 提示(旧版:OPENCLAW_TAILNET_DNS)。OPENCLAW_CLI_PATH覆盖广播的 CLI 路径(旧版:OPENCLAW_CLI_PATH)。
相关文档
- 发现策略和传输选择:发现
- 节点配对 + 审批:Gateway网关配对