环境与调试

调试

用于流式输出的调试辅助工具,尤其适用于提供商将推理内容混入普通文本时。

运行时调试覆盖

在聊天中使用 /debug 设置仅运行时配置覆盖(内存中,不写入磁盘)。 /debug 默认禁用;通过 commands.debug: true 启用。 当你需要切换冷门设置而不编辑 openclaw.json 时,这很方便。

示例:

/debug show
/debug set messages.responsePrefix="[openclaw]"
/debug unset messages.responsePrefix
/debug reset

/debug reset 会清除所有覆盖,并恢复为磁盘上的配置。

会话跟踪输出

当你想在一个会话中查看插件拥有的跟踪/调试行, 而不启用完整详细模式时,使用 /trace

示例:

/trace
/trace on
/trace off

/trace 用于插件诊断,例如 Active Memory 调试摘要。 继续使用 /verbose 查看常规详细状态/工具输出,并继续使用 /debug 进行仅运行时配置覆盖。

插件生命周期跟踪

当插件生命周期命令感觉缓慢,并且你需要针对插件元数据、设备发现、注册表、 运行时镜像、配置变更和刷新工作的内置阶段分解时,使用 OPENCLAW_PLUGIN_LIFECYCLE_TRACE=1。 该跟踪需要显式启用,并写入 stderr,因此 JSON 命令输出仍可解析。

示例:

OPENCLAW_PLUGIN_LIFECYCLE_TRACE=1 openclaw plugins install tokenjuice --force

示例输出:

[plugins:lifecycle] phase="config read" ms=6.83 status=ok command="install"
[plugins:lifecycle] phase="slot selection" ms=94.31 status=ok command="install" pluginId="tokenjuice"
[plugins:lifecycle] phase="registry refresh" ms=51.56 status=ok command="install" reason="source-changed"

在使用 CPU 分析器之前,先用它调查插件生命周期。 如果命令从源码 checkout 运行,建议在 pnpm build 之后用 node dist/entry.js ... 测量构建后的运行时;pnpm openclaw ... 也会测量源码运行器开销。

CLI 启动和命令性能分析

当某个命令感觉很慢时,使用仓库中已有的启动基准测试:

pnpm test:startup:bench:smoke
pnpm tsx scripts/bench-cli-startup.ts --preset real --case status --runs 3
pnpm tsx scripts/bench-cli-startup.ts --preset real --cpu-prof-dir .artifacts/cli-cpu

如需通过常规源码运行器进行一次性性能分析,请设置 OPENCLAW_RUN_NODE_CPU_PROF_DIR

OPENCLAW_RUN_NODE_CPU_PROF_DIR=.artifacts/cli-cpu pnpm openclaw status

源码运行器会添加 Node CPU profile 标志,并为该命令写入一个 .cpuprofile。 在向命令代码添加临时插桩之前,先使用这种方式。

对于看起来像同步文件系统或模块加载器工作的启动卡顿, 通过源码运行器添加 Node 的同步 I/O 跟踪标志:

OPENCLAW_TRACE_SYNC_IO=1 pnpm openclaw gateway --force

pnpm gateway:watch 会默认为被监视的 Gateway 网关子进程启用此标志。 设置 OPENCLAW_TRACE_SYNC_IO=0 可在 watch 模式中抑制 Node 同步 I/O 跟踪输出。

Gateway 网关 watch 模式

为了快速迭代,在文件监视器下运行 Gateway 网关:

pnpm gateway:watch

默认情况下,这会启动或重启名为 openclaw-gateway-watch-main 的 tmux 会话(或特定于 profile/端口的变体,例如 openclaw-gateway-watch-dev-19001),并从交互式终端自动附加。 非交互式 shell、CI 和智能体 exec 调用会保持分离,并改为打印附加说明。 需要时可手动附加:

tmux attach -t openclaw-gateway-watch-main

tmux pane 会运行原始监视器:

node scripts/watch-node.mjs gateway --force

当不需要 tmux 时,使用前台模式:

pnpm gateway:watch:raw
# or
OPENCLAW_GATEWAY_WATCH_TMUX=0 pnpm gateway:watch

在保留 tmux 管理的同时禁用自动附加:

OPENCLAW_GATEWAY_WATCH_ATTACH=0 pnpm gateway:watch

在调试启动/运行时热点时,对被监视的 Gateway 网关 CPU 时间进行性能分析:

pnpm gateway:watch --benchmark

watch 包装器会在调用 Gateway 网关之前消费 --benchmark,并在 .artifacts/gateway-watch-profiles/ 下为每次 Gateway 网关子进程退出写入一个 V8 .cpuprofile。停止或重启被监视的 Gateway 网关以刷新当前 profile, 然后用 Chrome DevTools 或 Speedscope 打开它:

npx speedscope .artifacts/gateway-watch-profiles/*.cpuprofile

当你希望把 profile 写到其他位置时,使用 --benchmark-dir <path>。 当你希望被基准测试的子进程跳过默认的 --force 端口清理,并在 Gateway 网关端口已被占用时快速失败时,使用 --benchmark-no-force。 benchmark 模式默认会抑制同步 I/O 跟踪噪音。当你明确同时需要 CPU profile 和 Node 同步 I/O 堆栈跟踪时,将 OPENCLAW_TRACE_SYNC_IO=1--benchmark 一起设置。在 benchmark 模式下,这些跟踪块会写入 benchmark 目录下的 gateway-watch-output.log,并从终端 pane 中过滤掉;常规 Gateway 网关日志仍然可见。

tmux 包装器会将常见的非机密运行时选择器带入 pane,例如 OPENCLAW_PROFILEOPENCLAW_CONFIG_PATHOPENCLAW_STATE_DIROPENCLAW_GATEWAY_PORTOPENCLAW_SKIP_CHANNELS。将 提供商凭证放在你的常规 profile/config 中,或者对一次性临时 secret 使用原始前台模式。 如果被监视的 Gateway 网关在启动期间退出,监视器会运行一次 openclaw doctor --fix --non-interactive,然后重启 Gateway 网关子进程。 当你想要保留原始启动失败、而不执行仅限开发的修复步骤时,使用 OPENCLAW_GATEWAY_WATCH_AUTO_DOCTOR=0。 托管 tmux pane 还默认使用彩色 Gateway 网关日志以提升可读性; 启动 pnpm gateway:watch 时设置 FORCE_COLOR=0 可禁用 ANSI 输出。

监视器会在 src/ 下与构建相关的文件、插件源码文件、 插件 package.jsonopenclaw.plugin.json 元数据、tsconfig.jsonpackage.json 以及 tsdown.config.ts 变更时重启。插件元数据变更会重启 Gateway 网关,而不强制执行 tsdown 重新构建;源码和配置变更仍会先重新构建 dist

gateway:watch 后添加任何 Gateway 网关 CLI 标志,它们都会在每次重启时透传。 重新运行同一个 watch 命令会重新生成命名的 tmux pane,而原始监视器仍会保留其单监视器锁, 因此重复的监视器父进程会被替换,而不是不断堆积。

开发 profile + 开发 Gateway 网关(--dev)

使用开发 profile 隔离状态,并启动一个安全、可丢弃的设置用于调试。 有两个 --dev 标志:

  • **全局 --dev(profile):**将状态隔离在 ~/.openclaw-dev 下,并将 Gateway 网关端口默认设为 19001(派生端口也随之偏移)。
  • gateway --dev:告诉 Gateway 网关在缺失时自动创建默认配置 + workspace(并跳过 BOOTSTRAP.md)。

推荐流程(开发 profile + 开发 bootstrap):

pnpm gateway:dev
OPENCLAW_PROFILE=dev openclaw tui

如果你还没有全局安装,请通过 pnpm openclaw ... 运行 CLI。

它会做这些事:

  1. Profile 隔离(全局 --dev

    • OPENCLAW_PROFILE=dev
    • OPENCLAW_STATE_DIR=~/.openclaw-dev
    • OPENCLAW_CONFIG_PATH=~/.openclaw-dev/openclaw.json
    • OPENCLAW_GATEWAY_PORT=19001(browser/canvas 会相应偏移)
  2. 开发 bootstrapgateway --dev

    • 如果缺失,则写入最小配置(gateway.mode=local,绑定 loopback)。
    • agent.workspace 设置为开发 workspace。
    • 设置 agent.skipBootstrap=true(无 BOOTSTRAP.md)。
    • 如果缺失,则填充 workspace 文件: AGENTS.mdSOUL.mdTOOLS.mdIDENTITY.mdUSER.mdHEARTBEAT.md
    • 默认身份:C3-PO(protocol droid)。
    • 在开发模式中跳过渠道提供商(OPENCLAW_SKIP_CHANNELS=1)。

重置流程(全新开始):

pnpm gateway:dev:reset

--reset 会擦除配置、凭证、会话和开发 workspace(使用 trash,而不是 rm),然后重新创建默认开发设置。

原始流日志(OpenClaw)

OpenClaw 可以在任何过滤/格式化之前记录原始助手流。 这是查看推理内容是否作为普通文本 delta 到达 (或作为单独 thinking 块到达)的最佳方式。

通过 CLI 启用:

pnpm gateway:watch --raw-stream

可选路径覆盖:

pnpm gateway:watch --raw-stream --raw-stream-path ~/.openclaw/logs/raw-stream.jsonl

等效环境变量:

OPENCLAW_RAW_STREAM=1
OPENCLAW_RAW_STREAM_PATH=~/.openclaw/logs/raw-stream.jsonl

默认文件:

~/.openclaw/logs/raw-stream.jsonl

原始 chunk 日志(pi-mono)

要在 raw OpenAI-compat chunks 被解析为块之前捕获它们, pi-mono 暴露了一个单独的 logger:

PI_RAW_STREAM=1

可选路径:

PI_RAW_STREAM_PATH=~/.pi-mono/logs/raw-openai-completions.jsonl

默认文件:

~/.pi-mono/logs/raw-openai-completions.jsonl

注意:这只由使用 pi-mono 的 openai-completions provider 的进程发出。

安全注意事项

  • 原始流日志可能包含完整 prompts、工具输出和用户数据。
  • 保持日志本地存放,并在调试后删除它们。
  • 如果你共享日志,请先清理 secret 和 PII。

在 VSCode 中调试

在基于 VSCode 的 IDE 中启用调试需要 source maps,因为许多生成文件在构建过程中最终会带有哈希名称。包含的 launch.json 配置面向 Gateway 网关服务,但可以快速改造用于其他目的:

  1. 重新构建并调试 Gateway 网关 - 在创建新构建后调试 Gateway 网关服务
  2. 调试 Gateway 网关 - 调试预先存在的构建中的 Gateway 网关服务

设置

默认的重新构建并调试 Gateway 网关配置开箱即用,它会自动删除 /dist 文件夹,并在启用调试的情况下重新构建项目:

  1. 从 Activity Bar 打开 Run and Debug 面板,或按 Ctrl+Shift+D
  2. 在 IDE 中,确保配置下拉菜单中选择了重新构建并调试 Gateway 网关,然后按 Start Debugging 按钮

或者,如果你更喜欢手动管理构建和调试流程:

  1. 打开终端并启用 source maps:
    • Linux/macOSexport OUTPUT_SOURCE_MAPS=1
    • Windows(PowerShell)$env:OUTPUT_SOURCE_MAPS="1"
    • Windows(CMD)set OUTPUT_SOURCE_MAPS=1
  2. 在同一个终端中,重新构建项目:pnpm clean:dist && pnpm build
  3. 在 IDE 中,在 Run and Debug 配置下拉菜单里选择调试 Gateway 网关选项,然后按 Start Debugging 按钮

现在,你可以在 TypeScript 源文件(src/ 目录)中设置断点,调试器会通过 source maps 将断点正确映射到编译后的 JavaScript。你将能够按预期检查变量、单步执行代码并查看调用栈。

注意事项

  • 如果使用 "Rebuild and Debug Gateway" 选项,每次启动调试器时,它都会完全删除 /dist 文件夹,并在启动 Gateway 网关之前运行一次启用 source maps 的完整 pnpm build
  • 如果使用 "Debug Gateway" 选项,可以随时启动和停止调试会话而不影响 /dist 文件夹,但你必须使用单独的终端进程来启用调试并管理构建周期
  • 修改 launch.json 中的 args 设置,以调试项目的其他部分
  • 如果你需要将构建后的 OpenClaw CLI 用于其他任务(即,如果你的调试会话生成了新的 auth token,则运行 dashboard --no-open),你可以在另一个终端中通过 node ./openclaw.mjs 执行它,或创建一个 shell alias,例如 alias openclaw-build="node $(pwd)/openclaw.mjs"

相关