OpenClaw 为代理提供了跨会话工作、检查状态以及编排子代理的工具。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.
可用工具
| 工具 | 作用 |
|---|---|
sessions_list | 列出会话,可选过滤条件包括 kind、label、agent、recency、preview |
sessions_history | 读取特定会话的对话记录 |
sessions_send | 向另一个会话发送消息,并可选择等待回复 |
sessions_spawn | 为后台工作生成一个隔离的子代理会话 |
sessions_yield | 结束当前轮次,并等待后续子代理结果 |
subagents | 列出、引导或终止此会话中已生成的子代理 |
session_status | 显示一个类似 /status 的卡片,并可选设置按会话生效的模型覆盖值 |
tools.profile: "coding" 包含完整的会话编排工具集,包括 sessions_spawn、sessions_yield 和 subagents。tools.profile: "messaging" 包含跨会话消息工具(sessions_list、sessions_history、sessions_send、session_status),但不包含子代理生成。若要保留 messaging 配置文件,同时仍允许原生委派,请添加:
/tools 来查看实际生效的工具列表。
列出和读取会话
sessions_list 会返回会话及其 key、agentId、kind、channel、model、token 数量和时间戳。可按 kind(main、group、cron、hook、node)、精确 label、精确 agentId、搜索文本或最近活跃时间(activeMinutes)进行过滤。当你需要类似邮箱的分拣时,它还可以请求一个按可见性范围派生的标题、最后一条消息的预览片段,或者每行受限的最近消息。派生标题和预览只会为调用方在已配置的会话工具可见性策略下本就可以看到的会话生成,因此无关会话会保持隐藏。
sessions_history 用于获取特定会话的对话记录。默认情况下会排除工具结果——传入 includeTools: true 以查看它们。返回视图经过有意的边界限制和安全过滤:
- assistant 文本在回忆前会被规范化:
- thinking 标签会被剥离
<relevant-memories>/<relevant_memories>脚手架块会被剥离- 纯文本工具调用 XML 负载块(如
<tool_call>...</tool_call>、<function_call>...</function_call>、<tool_calls>...</tool_calls>和<function_calls>...</function_calls>)会被剥离,包括从未完整闭合的截断负载 - 降级的工具调用/结果脚手架(如
[Tool Call: ...]、[Tool Result ...]和[Historical context ...])会被剥离 - 泄露的模型控制 token(如
<|assistant|>、其他 ASCII<|...|>token,以及全角<|...|>变体)会被剥离 - 形态异常的 MiniMax 工具调用 XML(如
<invoke ...>/</minimax:tool_call>)会被剥离
- 类似凭据/token 的文本在返回前会被脱敏
- 较长的文本块会被截断
- 非常大的历史记录可能会丢弃较早的行,或将过大的行替换为
[sessions_history omitted: message too large] - 该工具会报告
truncated、droppedMessages、contentTruncated、contentRedacted和bytes等汇总标志
"main")或来自先前 list 调用的会话 ID。
如果你需要逐字节完全一致的转录,请检查磁盘上的 transcript 文件,而不要把 sessions_history 当作原始转储。
跨会话发送消息
sessions_send 会向另一个会话传递消息,并可选择等待响应:
- 即发即弃: 设置
timeoutSeconds: 0,即可入队并立即返回。 - 等待回复: 设置超时时间并内联获取响应。
:thread:<id> 结尾的 Slack 或 Discord key,不是有效的 sessions_send 目标。请使用父频道会话 key 进行代理间协调,这样通过工具路由的消息就不会出现在正在进行的人类可见线程中。
消息和 A2A 后续回复会在接收提示词中([Inter-session message ... isUser=false])以及转录出处中标记为跨会话数据。接收代理应将它们视为通过工具路由的数据,而不是直接由终端用户撰写的指令。
目标方响应后,OpenClaw 可以运行一个回复回环,让代理轮流交替消息(最多 5 轮)。目标代理可以回复 REPLY_SKIP 以提前停止。
状态和编排辅助工具
session_status 是当前会话或其他可见会话的轻量级 /status 等价工具。它会报告用量、时间、模型/运行时状态,以及在存在时关联的后台任务上下文。与 /status 一样,它可以从最新的转录用量条目中回填稀疏的 token/cache 计数,而 model=default 会清除按会话生效的覆盖值。对调用方当前会话使用 sessionKey="current";诸如 openclaw-tui 之类的可见客户端标签并不是会话 key。
sessions_yield 会有意结束当前轮次,以便下一条消息可以成为你正在等待的后续事件。在生成子代理后使用它,当你希望完成结果作为下一条消息到达,而不是建立轮询循环时尤其适合。
subagents 是用于已生成 OpenClaw 子代理的控制平面辅助工具。它支持:
action: "list"用于检查活跃/最近运行action: "steer"用于向正在运行的子任务发送后续指导action: "kill"用于停止单个子任务或all
生成子代理
sessions_spawn 默认会为后台任务创建一个隔离会话。它始终是非阻塞的——会立即返回 runId 和 childSessionKey。
关键选项:
runtime: "subagent"(默认) or"acp"用于外部宿主代理。model和thinking可覆盖子会话设置。thread: true用于将生成操作绑定到聊天线程(Discord、Slack 等)。sandbox: "require"用于对子代理强制启用沙箱。context: "fork"用于本地子代理,当子代理需要当前请求者转录时使用;如需一个干净的子代理,可省略或使用context: "isolated"。 绑定线程的本地子代理默认使用context: "fork",除非threadBindings.defaultSpawnContext另有说明。
maxSpawnDepth >= 2 时,深度为 1 的编排子代理还会额外获得 sessions_spawn、subagents、sessions_list 和 sessions_history,以便它们管理自己的子任务。叶子运行仍然不会获得递归编排工具。
完成后,会有一个 announce 步骤将结果发布到请求者的频道。完成结果投递会在可用时保留绑定的线程/主题路由;如果完成来源只标识了一个频道,OpenClaw 仍可以重用请求者会话中存储的路由(lastChannel / lastTo)进行直接投递。
关于 ACP 的特定行为,请参见 ACP Agents。
可见性
会话工具的作用域会限制代理可见内容:| 级别 | 范围 |
|---|---|
self | 仅当前会话 |
tree | 当前会话 + 已生成的子代理 |
agent | 该代理的所有会话 |
all | 所有会话(若已配置,则跨代理) |
tree。无论配置如何,沙箱会话都被限制为 tree。
延伸阅读
- Session Management — 路由、生命周期、维护
- ACP Agents — 外部宿主生成
- Multi-agent — 多代理架构
- Gateway Configuration — 会话工具配置选项