Presence
Presence
适用范围
在以下情况使用此页面:
- 调试实例选项卡
- 调查重复或过时的实例行
- 更改网关 WS 连接或系统事件信标
Moltbot “presence"是一个轻量级的、尽力而为的视图,包括:
- 网关本身,以及
- 连接到网关的客户端(mac 应用、WebChat、CLI 等)
Presence 主要用于渲染 macOS 应用的实例选项卡,并为操作员提供快速可见性。
Presence 字段(显示内容)
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:最后更新时间戳(自纪元以来的毫秒数)
生产者(presence 来自哪里)
Presence 条目由多个源产生并合并。
1) 网关自条目
网关总是在启动时播种一个"自"条目,以便 UI 在任何客户端连接之前显示网关主机。
2) WebSocket 连接
每个 WS 客户端以 connect 请求开始。在成功握手时,网关为该连接更新 presence 条目。
为什么一次性 CLI 命令不显示
CLI 通常连接进行简短的一次性命令。为了避免刷屏实例列表,client.mode === "cli" 不会转换为 presence 条目。
3) system-event 信标
客户端可以通过 system-event 方法发送更丰富的定期信标。mac 应用使用它来报告主机名、IP 和 lastInputSeconds。
4) 节点连接(角色:node)
当节点通过网关 WebSocket 以 role: node 连接时,网关为该节点更新 presence 条目(与其他 WS 客户端的流程相同)。
合并 + 去重规则(为什么 instanceId 很重要)
Presence 条目存储在单个内存映射中:
- 条目由presence 键键控。
- 最好的键是稳定的
instanceId(来自connect.client.instanceId),它在重启后仍然存在。 - 键不区分大小写。
如果客户端在没有稳定的 instanceId 的情况下重新连接,它可能会显示为重复行。
TTL 和有界大小
Presence 故意是短暂的:
- TTL:超过 5 分钟的条目将被修剪
- 最大条目数:200(最旧的首先丢弃)
这使列表保持新鲜并避免无界的内存增长。
远程/隧道警告(环回 IP)
当客户端通过 SSH 隧道/本地端口转发连接时,网关可能会将远程地址视为 127.0.0.1。为了避免覆盖良好的客户端报告的 IP,环回远程地址将被忽略。
消费者
macOS 实例选项卡
macOS 应用渲染 system-presence 的输出,并根据最后更新的年龄应用小的状态指示器(活动/空闲/过时)。
调试提示
- 要查看原始列表,请对网关调用
system-presence。 - 如果您看到重复项:
- 确认客户端在握手中发送稳定的
client.instanceId - 确认定期信标使用相同的
instanceId - 检查连接派生的条目是否缺少
instanceId(重复是预期的)
- 确认客户端在握手中发送稳定的