轨迹捕获是 OpenClaw 按会话提供的飞行记录仪。它会为每次智能体运行记录一条 结构化时间线,然后Documentation Index
Fetch the complete documentation index at: https://docs.openclaw.ai/llms.txt
Use this file to discover all available pages before exploring further.
/export-trajectory 会将当前会话打包成经过脱敏的支持包。
当你需要回答如下问题时可以使用它:
- 哪些提示词、系统提示词和工具被发送给了模型?
- 哪些转录消息和工具调用导致了这个回答?
- 这次运行是否超时、中止、压缩,或遇到了提供商错误?
- 哪个模型、插件、Skills 和运行时设置处于活动状态?
- 提供商返回了哪些用量和提示词缓存元数据?
/diagnostics 开始。Diagnostics 会收集经过清理的
Gateway 网关包,并且对于 OpenAI Codex harness 会话,在获得批准后还可以将
Codex 反馈发送到 OpenAI 服务器。当你明确需要详细的按会话提示词、工具和转录
时间线时,请使用 /export-trajectory。
快速开始
在活动会话中发送:.openclaw/trajectory-exports/ 内解析。绝对路径和 ~ 路径会被拒绝。
轨迹包可以包含提示词、模型消息、工具架构、工具结果、运行时事件和本地路径。因此,
聊天斜杠命令每次都会经过 exec 审批。当你确实要创建该包时,只批准本次导出;不要使用 allow-all。在群聊中,OpenClaw 会把审批提示和导出结果私下发送给所有者,而不是把轨迹详情发回共享房间。
对于本地检查或支持工作流,你也可以直接运行已批准的命令路径:
访问权限
轨迹导出是所有者命令。发送者必须通过该渠道的常规命令授权检查和所有者检查。记录内容
默认情况下,OpenClaw 智能体运行会开启轨迹捕获。 运行时事件包括:session.startedtrace.metadatacontext.compiledprompt.submittedmodel.fallback_step,包括源模型、下一个模型、失败原因/详情、链中位置,以及 fallback 是否推进、成功或耗尽链model.completedtrace.artifactssession.ended
- 用户消息
- 助手消息
- 工具调用
- 工具结果
- 压缩
- 模型变更
- 标签和自定义会话条目
包文件
导出的包可以包含:| 文件 | 内容 |
|---|---|
manifest.json | 包架构、源文件、事件计数和生成的文件列表 |
events.jsonl | 有序的运行时和转录时间线 |
session-branch.json | 脱敏后的活动转录分支和会话头 |
metadata.json | OpenClaw 版本、操作系统/运行时、模型、配置快照、插件、Skills 和提示词元数据 |
artifacts.json | 最终状态、错误、用量、提示词缓存、压缩计数、助手文本和工具元数据 |
prompts.json | 已提交的提示词和选定的提示词构建详情 |
system-prompt.txt | 捕获到的最新已编译系统提示词 |
tools.json | 捕获到的发送给模型的工具定义 |
manifest.json 会列出该包中存在的文件。当会话没有捕获对应的运行时数据时,某些文件会被省略。
捕获位置
默认情况下,运行时轨迹事件会写在会话文件旁边:OPENCLAW_TRAJECTORY_DIR 可将运行时轨迹 sidecar 存储在专用目录中:
禁用捕获
在启动 OpenClaw 前设置OPENCLAW_TRAJECTORY=0:
/export-trajectory 仍然可以导出转录分支,但可能缺少已编译上下文、提供商产物和提示词元数据等仅运行时文件。
隐私和限制
轨迹包用于支持和调试,而不是公开发布。OpenClaw 会在写入导出文件前脱敏敏感值:- 凭据和已知类似机密的 payload 字段
- 图像数据
- 本地状态路径
- 工作区路径,会替换为
$WORKSPACE_DIR - 检测到的主目录路径
- 运行时 sidecar 文件:实时捕获会在 10 MiB 时停止,并在仍有空间时记录截断事件;导出接受最大 50 MiB 的现有运行时 sidecar
- 会话文件:50 MiB
- 运行时事件:200,000
- 导出事件总数:250,000
- 单条运行时事件行超过 256 KiB 时会被截断
故障排除
如果导出没有运行时事件:- 确认 OpenClaw 启动时未设置
OPENCLAW_TRAJECTORY=0 - 检查
OPENCLAW_TRAJECTORY_DIR是否指向可写目录 - 在会话中再运行一条消息,然后重新导出
- 检查
manifest.json中的runtimeEventCount
- 使用类似
bug-1234的相对名称 - 不要传入
/tmp/...或~/... - 将导出保留在
.openclaw/trajectory-exports/内