日志记录
有关面向用户的概览(CLI + 控制 UI + 配置),请参见 /logging。 OpenClaw 有两个日志“输出端”:- 控制台输出(你在终端 / 调试 UI 中看到的内容)。
- 文件日志(由网关日志记录器写入的 JSON 行格式日志)。
基于文件的日志记录器
- 默认滚动日志文件位于
/tmp/openclaw/(每日一个文件):openclaw-YYYY-MM-DD.log- 日期采用网关主机的本地时区。
- 日志文件路径和级别可通过
~/.openclaw/openclaw.json配置:logging.filelogging.level
logs.tail)实时跟踪此文件。CLI 也可以这样做:
- 文件日志 完全由
logging.level控制。 --verbose仅影响 控制台的详细程度(及 WS 日志样式);不会提升文件日志级别。- 若要在文件日志中捕获仅详细模式下才有的细节,请将
logging.level设为debug或trace。
控制台捕获
CLI 会捕获console.log/info/warn/error/debug/trace 并将其写入文件日志,同时依然打印至 stdout/stderr。
你可以通过以下配置独立调整控制台详细度:
logging.consoleLevel(默认info)logging.consoleStyle(pretty|compact|json)
工具摘要脱敏
详细的工具摘要(例如🛠️ Exec: ...)可以在输出到控制台流之前屏蔽敏感令牌。这仅限于 工具输出,不会修改文件日志。
logging.redactSensitive:off|tools(默认:tools)logging.redactPatterns:正则表达式字符串数组(覆盖默认规则)- 使用原始正则表达式字符串(自动带
gi标志),或者使用/pattern/flags指定自定义标志。 - 匹配的内容会保留前6个和后4个字符(长度 ≥ 18),否则全部替换为
***。 - 默认规则涵盖常见密钥赋值、CLI 参数、JSON 字段、Bearer 头、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的别名
控制台格式化(子系统日志)
控制台格式化器 支持 TTY 并打印统一带前缀的行。 子系统日志保持输出分组且易于扫描。 特性:- 每行打印 子系统前缀(如
[gateway]、[canvas]、[tailscale]) - 子系统颜色(对每个子系统固定)加上级别颜色
- 当输出为 TTY 或环境似乎为富终端(检查
TERM/COLORTERM/TERM_PROGRAM),启用颜色,尊重NO_COLOR - 简化子系统前缀:去除前导
gateway/和channels/,保留最后两个片段(例如whatsapp/outbound) - 按子系统分日志记录器(自动前缀 + 结构化字段
{ subsystem }) logRaw()用于二维码 / UX 输出(无前缀无格式)- 控制台样式(例如
pretty|compact|json) - 控制台日志级别独立于文件日志级别(文件日志在
logging.level设为debug/trace时仍保持完整细节) - WhatsApp 消息正文会以
debug级别记录(使用--verbose可查看)