Documentation Index
Fetch the complete documentation index at: https://openclaw.zhcndoc.com/llms.txt
Use this file to discover all available pages before exploring further.
TL;DR
根据你希望更新的频率以及是否想自己运行 Gateway,选择一种设置工作流:- 定制化存在于仓库之外: 将你的配置和工作区保存在
~/.openclaw/openclaw.json和~/.openclaw/workspace/中,这样仓库更新就不会影响它们。 - 稳定工作流(推荐给大多数人): 安装 macOS 应用并让它运行内置的 Gateway。
- 前沿工作流(开发): 通过
pnpm gateway:watch自己运行 Gateway,然后让 macOS 应用以本地模式连接。
前置条件(从源码)
- 推荐使用 Node 24(当前仍支持 Node 22 LTS,
22.14+) - 从源码检出时需要
pnpm。OpenClaw 在开发模式下会从extensions/*pnpm 工作区包中加载打包好的插件,因此根目录执行npm install不会准备完整的源码树。 - Docker(可选;仅用于容器化设置/端到端测试——见 Docker)
定制化策略(让更新不会伤到你)
如果你想要“完全按我定制”_并且_还能轻松更新,请将你的自定义内容保存在:- 配置:
~/.openclaw/openclaw.json(JSON/JSON5 风格) - 工作区:
~/.openclaw/workspace(技能、提示词、记忆;建议将其设为私有 git 仓库)
pnpm openclaw setup.
从本仓库运行 Gateway
在pnpm build 之后,你可以直接运行打包好的 CLI:
稳定工作流(优先使用 macOS 应用)
- 安装并启动 OpenClaw.app(菜单栏应用)。
- 完成入门/权限检查清单(TCC 提示)。
- 确保 Gateway 处于 Local 且正在运行(由应用管理它)。
- 连接各个渠道(示例:WhatsApp):
- 健康检查:
- 运行
openclaw setup,然后运行openclaw channels login,最后手动启动 Gateway(openclaw gateway)。
前沿工作流(在终端中运行 Gateway)
目标:开发 TypeScript Gateway,获得热重载,同时保持 macOS 应用 UI 连接。0)(可选)也从源码运行 macOS 应用
如果你也想让 macOS 应用走前沿版本:1) 启动开发版 Gateway
gateway:watch 会在一个命名的 tmux 会话中启动或重启 Gateway 监视进程,并在交互式终端中自动附加。非交互式 shell 会保持分离,并打印 tmux attach -t openclaw-gateway-watch-main;可使用 OPENCLAW_GATEWAY_WATCH_ATTACH=0 pnpm gateway:watch 让交互式运行保持分离,或使用 pnpm gateway:watch:raw 以前台监视模式运行。监视器会在相关源码、配置和打包插件元数据发生变化时重新加载。如果被监视的 Gateway 在启动期间退出,gateway:watch 会先运行一次 openclaw doctor --fix --non-interactive,然后重试;设置 OPENCLAW_GATEWAY_WATCH_AUTO_DOCTOR=0 可禁用这一步仅用于开发的修复流程。pnpm openclaw setup 是在全新检出后进行一次性的本地配置/工作区初始化步骤。
pnpm gateway:watch 不会重建 dist/control-ui,因此在 ui/ 变更后请重新运行 pnpm ui:build,或者在开发 Control UI 时使用 pnpm ui:dev。
2) Point the macOS app at your running Gateway
在 OpenClaw.app 中:- Connection Mode: Local 应用将连接到已在配置端口上运行的 gateway。
3) 验证
- 应用内的 Gateway 状态应显示 “Using existing gateway …”
- 或通过 CLI:
常见坑
- 端口错误: Gateway WS 默认是
ws://127.0.0.1:18789;让应用和 CLI 使用相同端口。 - 状态存放位置:
- 渠道/提供者状态:
~/.openclaw/credentials/ - 模型认证配置文件:
~/.openclaw/agents/<agentId>/agent/auth-profiles.json - 会话:
~/.openclaw/agents/<agentId>/sessions/ - 日志:
/tmp/openclaw/
- 渠道/提供者状态:
凭据存储映射
调试认证或决定要备份哪些内容时可参考这里:- WhatsApp:
~/.openclaw/credentials/whatsapp/<accountId>/creds.json - Telegram bot token:配置/env 或
channels.telegram.tokenFile(仅支持普通文件;拒绝符号链接) - Discord bot token:配置/env 或 SecretRef(env/file/exec 提供器)
- Slack tokens:配置/env(
channels.slack.*) - 配对允许名单:
~/.openclaw/credentials/<channel>-allowFrom.json(默认账户)~/.openclaw/credentials/<channel>-<accountId>-allowFrom.json(非默认账户)
- 模型认证配置文件:
~/.openclaw/agents/<agentId>/agent/auth-profiles.json - 文件后备的密钥载荷(可选):
~/.openclaw/secrets.json - 旧版 OAuth 导入:
~/.openclaw/credentials/oauth.json更多细节:安全。
更新(不破坏你的设置)
- 将
~/.openclaw/workspace和~/.openclaw/视为“你的内容”;不要把个人提示词/配置放进openclaw仓库中。 - 更新源码:
git pull+pnpm install+ 继续使用pnpm gateway:watch。
Linux(systemd 用户服务)
Linux 安装使用 systemd 用户 服务。默认情况下,systemd 会在注销/空闲时停止用户 服务,这会杀掉 Gateway。入门流程会尝试为你启用 lingering(可能会提示 sudo)。如果它仍然关闭,请运行:相关文档
- Gateway 操作手册(标志、监管、端口)
- Gateway 配置(配置 schema + 示例)
- Discord 和 Telegram(回复标签 + replyToMode 设置)
- OpenClaw 助手设置
- macOS 应用(gateway 生命周期)