Skip to main content

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.

轨迹捕获是 OpenClaw 按会话提供的飞行记录仪。它会为每次智能体运行记录一条 结构化时间线,然后 /export-trajectory 会将当前会话打包成经过脱敏的支持包。 当你需要回答如下问题时可以使用它:
  • 哪些提示词、系统提示词和工具被发送给了模型?
  • 哪些转录消息和工具调用导致了这个回答?
  • 这次运行是否超时、中止、压缩,或遇到了提供商错误?
  • 哪个模型、插件、Skills 和运行时设置处于活动状态?
  • 提供商返回了哪些用量和提示词缓存元数据?
如果你要为实时 Gateway 网关问题提交宽泛的支持报告,请从 /diagnostics 开始。Diagnostics 会收集经过清理的 Gateway 网关包,并且对于 OpenAI Codex harness 会话,在获得批准后还可以将 Codex 反馈发送到 OpenAI 服务器。当你明确需要详细的按会话提示词、工具和转录 时间线时,请使用 /export-trajectory

快速开始

在活动会话中发送:
/export-trajectory
别名:
/trajectory
OpenClaw 会将包写入工作区下:
.openclaw/trajectory-exports/openclaw-trajectory-<session>-<timestamp>/
你可以选择一个相对输出目录名:
/export-trajectory bug-1234
自定义路径会在 .openclaw/trajectory-exports/ 内解析。绝对路径和 ~ 路径会被拒绝。 轨迹包可以包含提示词、模型消息、工具架构、工具结果、运行时事件和本地路径。因此, 聊天斜杠命令每次都会经过 exec 审批。当你确实要创建该包时,只批准本次导出;不要使用 allow-all。在群聊中,OpenClaw 会把审批提示和导出结果私下发送给所有者,而不是把轨迹详情发回共享房间。 对于本地检查或支持工作流,你也可以直接运行已批准的命令路径:
openclaw sessions export-trajectory --session-key "agent:main:telegram:direct:123" --workspace .

访问权限

轨迹导出是所有者命令。发送者必须通过该渠道的常规命令授权检查和所有者检查。

记录内容

默认情况下,OpenClaw 智能体运行会开启轨迹捕获。 运行时事件包括:
  • session.started
  • trace.metadata
  • context.compiled
  • prompt.submitted
  • model.fallback_step,包括源模型、下一个模型、失败原因/详情、链中位置,以及 fallback 是否推进、成功或耗尽链
  • model.completed
  • trace.artifacts
  • session.ended
转录事件也会从活动会话分支重建:
  • 用户消息
  • 助手消息
  • 工具调用
  • 工具结果
  • 压缩
  • 模型变更
  • 标签和自定义会话条目
事件会以 JSON Lines 写入,并带有这个架构标记:
{
  "traceSchema": "openclaw-trajectory",
  "schemaVersion": 1
}

包文件

导出的包可以包含:
文件内容
manifest.json包架构、源文件、事件计数和生成的文件列表
events.jsonl有序的运行时和转录时间线
session-branch.json脱敏后的活动转录分支和会话头
metadata.jsonOpenClaw 版本、操作系统/运行时、模型、配置快照、插件、Skills 和提示词元数据
artifacts.json最终状态、错误、用量、提示词缓存、压缩计数、助手文本和工具元数据
prompts.json已提交的提示词和选定的提示词构建详情
system-prompt.txt捕获到的最新已编译系统提示词
tools.json捕获到的发送给模型的工具定义
manifest.json 会列出该包中存在的文件。当会话没有捕获对应的运行时数据时,某些文件会被省略。

捕获位置

默认情况下,运行时轨迹事件会写在会话文件旁边:
<session>.trajectory.jsonl
OpenClaw 还会尽力在会话旁写入一个指针文件:
<session>.trajectory-path.json
设置 OPENCLAW_TRAJECTORY_DIR 可将运行时轨迹 sidecar 存储在专用目录中:
export OPENCLAW_TRAJECTORY_DIR=/var/lib/openclaw/trajectories
设置此变量后,OpenClaw 会在该目录中为每个会话 id 写入一个 JSONL 文件。 当所属会话条目被会话磁盘预算修剪、封顶或逐出时,会话维护会移除轨迹 sidecar。位于会话目录之外的运行时文件,只有在指针目标仍能证明它属于该会话时才会被移除。

禁用捕获

在启动 OpenClaw 前设置 OPENCLAW_TRAJECTORY=0
export 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/
如果导出因大小错误而失败,说明会话或 sidecar 超出了导出安全限制。请启动新会话或导出更小的复现。

相关内容