OpenClaw “presence” 是一个轻量级、尽力而为的视图,用于展示:Documentation Index
Fetch the complete documentation index at: https://openclaw.zhcndoc.com/llms.txt
Use this file to discover all available pages before exploring further.
- Gateway 本身,以及
- 连接到 Gateway 的客户端(mac 应用、WebChat、CLI 等)
Presence fields (what shows up)
Presence 条目是结构化对象,包含如下字段:instanceId(可选但强烈推荐):稳定的客户端身份(通常是connect.client.instanceId)host:人类可读的主机名ip:尽力而为的 IP 地址version:客户端版本字符串deviceFamily/modelIdentifier:硬件提示mode:ui、webchat、cli、backend、probe、test、node、…lastInputSeconds:距离上次用户输入的“秒数”(如果已知)reason:self、connect、node-connected、periodic、…ts:最后更新时间戳(自 epoch 起的毫秒数)
Producers (where presence comes from)
Presence 条目由多个来源产生,并被合并。1) Gateway 自身条目
Gateway 会在启动时始终先种入一个“self”条目,因此即使还没有任何客户端连接,UI 也能显示 gateway 主机。2) WebSocket connect
每个 WS 客户端都以一个connect 请求开始。握手成功后,Gateway 会为该连接 upsert 一条 presence 条目。
为什么一次性 CLI 命令不会显示出来
CLI 通常只为短暂的一次性命令建立连接。为了避免刷屏 Instances 列表,client.mode === "cli" 不会 被转换为 presence 条目。
3) system-event beacons
客户端可以通过 system-event 方法发送更丰富的周期性 beacon。mac 应用使用它来报告主机名、IP 和 lastInputSeconds。
4) Node connects (role: node)
当某个 node 通过 Gateway WebSocket 以role: node 连接时,Gateway 会为该 node upsert 一条 presence 条目(与其他 WS 客户端流程相同)。
Merge + dedupe rules (why instanceId matters)
Presence 条目存储在一个单一的内存 map 中:
- 条目以一个 presence key 为键。
- 最佳的 key 是稳定的
instanceId(来自connect.client.instanceId),它能在重启后保持不变。 - Key 不区分大小写。
instanceId 的情况下重新连接,它可能会显示为一行重复条目。
TTL and bounded size
Presence 是刻意设计为短暂存在的:- TTL: 超过 5 分钟的条目会被清理
- 最大条目数: 200(优先丢弃最旧的)
Remote/tunnel caveat (loopback IPs)
当客户端通过 SSH 隧道 / 本地端口转发连接时,Gateway 可能会将远端地址视为127.0.0.1。为了避免覆盖客户端上报的正确 IP,loopback 远端地址会被忽略。
Consumers
macOS Instances tab
macOS 应用会渲染system-presence 的输出,并根据最后更新时间的年龄应用一个小型状态指示器(Active/Idle/Stale)。
Debugging tips
- 要查看原始列表,请针对 Gateway 调用
system-presence。 - 如果你看到重复项:
- 确认客户端在握手中发送了稳定的
client.instanceId - 确认周期性 beacon 使用的是相同的
instanceId - 检查基于连接生成的条目是否缺少
instanceId(出现重复是预期行为)
- 确认客户端在握手中发送了稳定的