日志记录
对于用户界面概述(CLI + 控制UI + 配置),请参阅 /logging。
OpenClaw 有两个日志“表面”:
- 控制台输出(你在终端/调试UI中看到的内容)。
- 文件日志(JSON 行)由网关日志器写入。
基于文件的日志记录器
- 默认滚动日志文件位于
/tmp/openclaw/(每天一个文件):openclaw-YYYY-MM-DD.log- 日期使用网关主机的本地时区。
- 日志文件路径和级别可以通过
~/.openclaw/openclaw.json进行配置:logging.filelogging.level
文件格式为每行一个 JSON 对象。
控制UI 日志选项卡通过网关跟踪此文件 (logs.tail)。
CLI 也可以这样做:
openclaw logs --follow
详细模式与日志级别
- 文件日志 仅由
logging.level控制。 --verbose仅影响 控制台详细程度(和 WS 日志样式);它不会提高文件日志级别。- 要在文件日志中捕获仅详细模式的信息,请将
logging.level设置为debug或trace。
控制台捕获
CLI 捕获 console.log/info/warn/error/debug/trace 并将其写入文件日志,
同时仍打印到 stdout/stderr。
你可以独立调整控制台详细程度:
logging.consoleLevel(默认info)-
logging.consoleStyle(prettycompactjson)
工具摘要红action
详细的工具摘要(例如 🛠️ Exec: ...)可以在它们到达控制台流之前屏蔽敏感令牌。这是 仅限工具 的,并不改变文件日志。
-
logging.redactSensitive:offtools(默认:tools) logging.redactPatterns: 正则表达式字符串数组(覆盖默认值)- 使用原始正则表达式字符串(自动
gi),或者使用/pattern/flags如果你需要自定义标志。 - 匹配项通过保留前6个和最后4个字符进行屏蔽(长度 >= 18),否则
***。 - 默认值涵盖常见的密钥分配、CLI 标志、JSON 字段、承载头、PEM 块和流行的令牌前缀。
- 使用原始正则表达式字符串(自动
网关 WebSocket 日志
网关以两种模式打印 WebSocket 协议日志:
- 正常模式(无
--verbose):仅打印“有趣的”RPC 结果:- 错误 (
ok=false) - 慢调用(默认阈值:
>= 50ms) - 解析错误
- 错误 (
- 详细模式 (
--verbose):打印所有 WS 请求/响应流量。
WS 日志样式
openclaw gateway 支持每个网关的样式切换:
--ws-log auto(默认):正常模式经过优化;详细模式使用紧凑输出--ws-log compact:详细模式下使用紧凑输出(配对请求/响应)--ws-log full:详细模式下使用完整帧输出--compact:--ws-log compact的别名
示例:
# optimized (only errors/slow)
openclaw gateway
# show all WS traffic (paired)
openclaw gateway --verbose --ws-log compact
# show all WS traffic (full meta)
openclaw gateway --verbose --ws-log full
控制台格式化(子系统日志记录)
控制台格式化程序是 终端感知 的,并打印一致的、带前缀的行。 子系统日志记录器保持输出分组且可扫描。
行为:
- 每行子系统前缀(例如
[gateway],[canvas],[tailscale]) - 子系统颜色(每个子系统稳定)加上级别着色
- 当输出是终端或环境看起来像富终端时着色 (
TERM/COLORTERM/TERM_PROGRAM),尊重NO_COLOR - 缩短的子系统前缀:丢弃前面的
gateway/+channels/,保留最后两个段(例如whatsapp/outbound) - 按子系统划分的子日志记录器(自动前缀 + 结构化字段
{ subsystem }) logRaw()用于 QR/UX 输出(无前缀,无格式)- 控制台样式(例如
pretty | compact | json) - 控制台日志级别 与文件日志级别分开(文件在
logging.level设置为debug/trace时保持完整细节) - WhatsApp 消息正文 记录在
debug(使用--verbose查看它们)
这保持现有文件日志的稳定性,同时使交互输出可扫描。