日志(macOS)
滚动诊断文件日志(Debug 面板)
OpenClaw 通过 swift-log 路由 macOS 应用日志(默认使用统一日志),当你需要持久化捕获时,可以将本地滚动文件日志写入磁盘。
- 详细程度:Debug 面板 → Logs → App logging → Verbosity
- 启用:Debug 面板 → Logs → App logging → “Write rolling diagnostics log (JSONL)”
- 位置:
~/Library/Logs/OpenClaw/diagnostics.jsonl(自动轮转;旧文件会添加.1、.2等后缀) - 清除:Debug 面板 → Logs → App logging → “Clear”
注意事项:
- 这个功能默认关闭。只在主动调试时启用。
- 把这个文件当作敏感信息;分享前务必检查内容。
macOS 统一日志的私有数据
统一日志会隐藏大部分内容,除非子系统选择启用 privacy -off。根据 Peter 关于 macOS 日志隐私问题的文章(2025),这是通过 /Library/Preferences/Logging/Subsystems/ 中的 plist 文件控制的,以子系统名称为键。只有新的日志条目会应用这个标志,所以要在重现问题之前启用它。
为 OpenClaw 启用(bot.molt)
- 先将 plist 写入临时文件,然后以 root 权限原子化安装:
cat <<'EOF' >/tmp/bot.molt.plist
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
<plist version="1.0">
<dict>
<key>DEFAULT-OPTIONS</key>
<dict>
<key>Enable-Private-Data</key>
<true/>
</dict>
</dict>
</plist>
EOF
sudo install -m 644 -o root -g wheel /tmp/bot.molt.plist /Library/Preferences/Logging/Subsystems/bot.molt.plist
- 不需要重启;logd 会很快注意到这个文件,但只有新的日志行才会包含私有内容。
- 用现有的辅助脚本查看更丰富的输出,例如
./scripts/clawlog.sh --category WebChat --last 5m。
调试后禁用
- 删除覆盖配置:
sudo rm /Library/Preferences/Logging/Subsystems/bot.molt.plist。 - 可选:运行
sudo log config --reload强制 logd 立即删除覆盖配置。 - 记住这个功能可能会包含电话号码和消息内容;只在你确实需要额外细节时才保留这个 plist 文件。