跳转到主要内容

Documentation Index

Fetch the complete documentation index at: https://docs.openclaw.ai/llms.txt

Use this file to discover all available pages before exploring further.

OpenClaw 从 ~/.openclaw/openclaw.json 读取可选的 配置。 活动配置路径必须是常规文件。符号链接的 openclaw.json 布局不支持 OpenClaw 拥有的写入;原子写入可能会替换 该路径,而不是保留符号链接。如果你将配置保存在默认状态目录 之外,请将 OPENCLAW_CONFIG_PATH 直接指向真实文件。 如果文件缺失,OpenClaw 会使用安全默认值。添加配置的常见原因:
  • 连接渠道并控制谁可以给 bot 发送消息
  • 设置模型、工具、沙箱隔离或自动化(cron、钩子)
  • 调整会话、媒体、网络或 UI
查看完整参考了解每个可用字段。 智能体和自动化在编辑配置前,应使用 config.schema.lookup 获取精确的字段级 文档。此页面提供面向任务的指导;配置参考 提供更完整的字段映射和默认值。
刚开始使用配置?openclaw onboard 开始进行交互式设置,或查看 Configuration Examples 指南获取完整的可复制粘贴配置。

最小配置

// ~/.openclaw/openclaw.json
{
  agents: { defaults: { workspace: "~/.openclaw/workspace" } },
  channels: { whatsapp: { allowFrom: ["+15555550123"] } },
}

编辑配置

openclaw onboard       # full onboarding flow
openclaw configure     # config wizard

严格校验

OpenClaw 只接受完全匹配 schema 的配置。未知键、格式错误的类型或无效值会导致 Gateway 网关拒绝启动。唯一的根级例外是 $schema(字符串),这样编辑器可以附加 JSON Schema 元数据。
openclaw config schema 会打印控制 UI 和校验使用的规范 JSON Schema。 config.schema.lookup 会获取单个路径作用域节点及其子项摘要,用于下钻工具。 字段 title/description 文档元数据会贯穿嵌套对象、通配符(*)、 数组项([])以及 anyOf/oneOf/allOf 分支。加载清单注册表后, 运行时插件和渠道 schema 会合并进来。 校验失败时:
  • Gateway 网关不会启动
  • 只有诊断命令可用(openclaw doctoropenclaw logsopenclaw healthopenclaw status
  • 运行 openclaw doctor 查看精确问题
  • 运行 openclaw doctor --fix(或 --yes)应用修复
Gateway 网关在每次成功启动后都会保留一份可信的最近一次可用副本, 但启动和热重载不会自动恢复它。如果 openclaw.json 校验失败(包括插件本地校验),Gateway 网关启动会失败,或 重载会被跳过,当前运行时保留最后一次被接受的配置。 运行 openclaw doctor --fix(或 --yes)来修复带前缀/被覆盖的配置,或 恢复最近一次可用副本。当候选配置包含已脱敏的密钥占位符(如 ***)时, 会跳过提升为最近一次可用副本。

常见任务

每个渠道在 channels.<provider> 下都有自己的配置段。设置步骤请查看对应的渠道页面:所有渠道共享相同的私信策略模式:
{
  channels: {
    telegram: {
      enabled: true,
      botToken: "123:abc",
      dmPolicy: "pairing",   // pairing | allowlist | open | disabled
      allowFrom: ["tg:123"], // only for allowlist/open
    },
  },
}
设置主模型和可选回退项:
{
  agents: {
    defaults: {
      model: {
        primary: "anthropic/claude-sonnet-4-6",
        fallbacks: ["openai/gpt-5.4"],
      },
      models: {
        "anthropic/claude-sonnet-4-6": { alias: "Sonnet" },
        "openai/gpt-5.4": { alias: "GPT" },
      },
    },
  },
}
  • agents.defaults.models 定义模型目录,并作为 /model 的允许列表。
  • 使用 openclaw config set agents.defaults.models '<json>' --strict-json --merge 添加允许列表条目,而不移除现有模型。除非传入 --replace,否则会移除条目的普通替换会被拒绝。
  • 模型引用使用 provider/model 格式(例如 anthropic/claude-opus-4-6)。
  • agents.defaults.imageMaxDimensionPx 控制 transcript/工具图片缩小(默认 1200);较低的值通常会在截图密集的运行中减少视觉 token 用量。
  • 参见 Models CLI 了解如何在聊天中切换模型,并参见 Model Failover 了解鉴权轮换和回退行为。
  • 对于自定义/自托管提供商,请参见参考中的自定义提供商
私信访问通过 dmPolicy 按渠道控制:
  • "pairing"(默认):未知发送者会收到一次性配对码以进行批准
  • "allowlist":仅允许 allowFrom 中的发送者(或已配对允许存储中的发送者)
  • "open":允许所有入站私信(需要 allowFrom: ["*"]
  • "disabled":忽略所有私信
对于群组,请使用 groupPolicy + groupAllowFrom 或渠道专用允许列表。按渠道的详细信息请参见完整参考
群组消息默认需要提及。按智能体配置触发模式,并将可见房间回复保持在默认的消息工具路径,除非你有意使用旧版自动最终回复:
{
  messages: {
    visibleReplies: "automatic", // set "message_tool" to require message-tool sends everywhere
    groupChat: {
      visibleReplies: "message_tool", // default; use "automatic" for legacy room replies
    },
  },
  agents: {
    list: [
      {
        id: "main",
        groupChat: {
          mentionPatterns: ["@openclaw", "openclaw"],
        },
      },
    ],
  },
  channels: {
    whatsapp: {
      groups: { "*": { requireMention: true } },
    },
  },
}
  • 元数据提及:原生 @ 提及(WhatsApp 点按提及、Telegram @bot 等)
  • 文本模式mentionPatterns 中的安全正则模式
  • 可见回复messages.visibleReplies 可以全局要求通过消息工具发送;messages.groupChat.visibleReplies 会为群组/渠道覆盖该设置。
  • 查看完整参考,了解可见回复模式、按渠道覆盖和自聊模式。
使用 agents.defaults.skills 作为共享基线,然后用 agents.list[].skills 覆盖特定智能体:
{
  agents: {
    defaults: {
      skills: ["github", "weather"],
    },
    list: [
      { id: "writer" }, // inherits github, weather
      { id: "docs", skills: ["docs-search"] }, // replaces defaults
      { id: "locked-down", skills: [] }, // no skills
    ],
  },
}
  • 省略 agents.defaults.skills 时,默认不限制 Skills。
  • 省略 agents.list[].skills 时继承默认值。
  • agents.list[].skills 设为 [] 表示没有 Skills。
  • 参见 SkillsSkills 配置,以及 配置参考
控制 Gateway 网关对看起来停滞的渠道进行重启的激进程度:
{
  gateway: {
    channelHealthCheckMinutes: 5,
    channelStaleEventThresholdMinutes: 30,
    channelMaxRestartsPerHour: 10,
  },
  channels: {
    telegram: {
      healthMonitor: { enabled: false },
      accounts: {
        alerts: {
          healthMonitor: { enabled: true },
        },
      },
    },
  },
}
  • gateway.channelHealthCheckMinutes: 0 设为全局禁用健康监控重启。
  • channelStaleEventThresholdMinutes 应大于或等于检查间隔。
  • 使用 channels.<provider>.healthMonitor.enabledchannels.<provider>.accounts.<id>.healthMonitor.enabled 可为某个渠道或账号禁用自动重启,而不禁用全局监控。
  • 参见 Health Checks 进行运维调试,并参见完整参考了解所有字段。
在负载较高或性能较低的主机上,给本地客户端更多时间完成鉴权前 WebSocket 握手:
{
  gateway: {
    handshakeTimeoutMs: 30000,
  },
}
  • 默认值为 15000 毫秒。
  • OPENCLAW_HANDSHAKE_TIMEOUT_MS 对一次性服务或 shell 覆盖仍然优先。
  • 优先修复启动/事件循环停顿;此旋钮用于健康但预热期间较慢的主机。
在隔离的沙箱运行时中运行智能体会话:
{
  agents: {
    defaults: {
      sandbox: {
        mode: "non-main",  // off | non-main | all
        scope: "agent",    // session | agent | shared
      },
    },
  },
}
先构建镜像 — 如果是源码 checkout,请运行 scripts/sandbox-setup.sh;如果是 npm 安装,请参阅 沙箱隔离 § 镜像和设置中的内联 docker build 命令。请参阅沙箱隔离了解完整指南,并参阅完整参考了解所有选项。
relay-backed push 在 openclaw.json 中配置。在 Gateway 网关配置中设置:
{
  gateway: {
    push: {
      apns: {
        relay: {
          baseUrl: "https://relay.example.com",
          // Optional. Default: 10000
          timeoutMs: 10000,
        },
      },
    },
  },
}
CLI 等效命令:
openclaw config set gateway.push.apns.relay.baseUrl https://relay.example.com
这会执行以下操作:
  • 让 Gateway 网关通过外部中继发送 push.test、唤醒提示和重连唤醒。
  • 使用由已配对 iOS 应用转发的、限定在注册范围内的发送授权。Gateway 网关不需要部署级中继 token。
  • 将每个 relay-backed 注册绑定到 iOS 应用配对的 Gateway 网关身份,因此其他 Gateway 网关无法复用已存储的注册。
  • 让本地/手动 iOS 构建继续使用直接 APNs。relay-backed 发送仅适用于通过中继注册的官方分发构建。
  • 必须匹配内置到官方/TestFlight iOS 构建中的中继基础 URL,以便注册和发送流量到达同一个中继部署。
端到端流程:
  1. 安装使用相同中继基础 URL 编译的官方/TestFlight iOS 构建。
  2. 在 Gateway 网关上配置 gateway.push.apns.relay.baseUrl
  3. 将 iOS 应用与 Gateway 网关配对,并让节点会话和操作者会话都连接。
  4. iOS 应用获取 Gateway 网关身份,使用 App Attest 加应用收据向中继注册,然后将 relay-backed push.apns.register 载荷发布到已配对的 Gateway 网关。
  5. Gateway 网关存储中继 handle 和发送授权,然后将它们用于 push.test、唤醒提示和重连唤醒。
运维说明:
  • 如果你将 iOS 应用切换到另一个 Gateway 网关,请重新连接应用,使其能够发布绑定到该 Gateway 网关的新中继注册。
  • 如果你发布的新 iOS 构建指向不同的中继部署,应用会刷新其缓存的中继注册,而不是复用旧的中继来源。
兼容性说明:
  • OPENCLAW_APNS_RELAY_BASE_URLOPENCLAW_APNS_RELAY_TIMEOUT_MS 仍可作为临时环境变量覆盖项使用。
  • OPENCLAW_APNS_RELAY_ALLOW_HTTP=true 仍是仅限 local loopback 的开发逃生口;不要在配置中持久保存 HTTP 中继 URL。
请参阅 iOS 应用了解端到端流程,并参阅身份验证和信任流程了解中继安全模型。
{
  agents: {
    defaults: {
      heartbeat: {
        every: "30m",
        target: "last",
      },
    },
  },
}
  • every:时长字符串(30m2h)。设置为 0m 可禁用。
  • targetlast | none | <channel-id>(例如 discordmatrixtelegramwhatsapp
  • directPolicy:对于私信样式的 Heartbeat 目标,使用 allow(默认)或 block
  • 请参阅 Heartbeat了解完整指南。
{
  cron: {
    enabled: true,
    maxConcurrentRuns: 2, // cron dispatch + isolated cron agent-turn execution
    sessionRetention: "24h",
    runLog: {
      maxBytes: "2mb",
      keepLines: 2000,
    },
  },
}
  • sessionRetention:从 sessions.json 中清理已完成的隔离运行会话(默认 24h;设置为 false 可禁用)。
  • runLog:按大小和保留行数清理 cron/runs/<jobId>.jsonl
  • 请参阅 Cron 作业了解功能概览和 CLI 示例。
在 Gateway 网关上启用 HTTP webhook 端点:
{
  hooks: {
    enabled: true,
    token: "shared-secret",
    path: "/hooks",
    defaultSessionKey: "hook:ingress",
    allowRequestSessionKey: false,
    allowedSessionKeyPrefixes: ["hook:"],
    mappings: [
      {
        match: { path: "gmail" },
        action: "agent",
        agentId: "main",
        deliver: true,
      },
    ],
  },
}
安全说明:
  • 将所有 hook/webhook 载荷内容视为不受信任的输入。
  • 使用专用的 hooks.token;不要复用共享 Gateway 网关 token。
  • Hook 认证仅支持 header(Authorization: Bearer ...x-openclaw-token);查询字符串 token 会被拒绝。
  • hooks.path 不能是 /;将 webhook 入口保留在专用子路径上,例如 /hooks
  • 除非进行严格限定范围的调试,否则保持不安全内容绕过标志禁用(hooks.gmail.allowUnsafeExternalContenthooks.mappings[].allowUnsafeExternalContent)。
  • 如果启用 hooks.allowRequestSessionKey,也要设置 hooks.allowedSessionKeyPrefixes,以约束调用方选择的会话键。
  • 对于 hook 驱动的智能体,优先使用强大的现代模型层级和严格的工具策略(例如仅消息传递,并尽可能使用沙箱隔离)。
请参阅完整参考了解所有映射选项和 Gmail 集成。
使用独立工作区和会话运行多个隔离智能体:
{
  agents: {
    list: [
      { id: "home", default: true, workspace: "~/.openclaw/workspace-home" },
      { id: "work", workspace: "~/.openclaw/workspace-work" },
    ],
  },
  bindings: [
    { agentId: "home", match: { channel: "whatsapp", accountId: "personal" } },
    { agentId: "work", match: { channel: "whatsapp", accountId: "biz" } },
  ],
}
请参阅 Multi-Agent完整参考,了解绑定规则和每智能体访问配置文件。
使用 $include 组织大型配置:
// ~/.openclaw/openclaw.json
{
  gateway: { port: 18789 },
  agents: { $include: "./agents.json5" },
  broadcast: {
    $include: ["./clients/a.json5", "./clients/b.json5"],
  },
}
  • 单个文件:替换包含它的对象
  • 文件数组:按顺序深度合并(后者优先)
  • 同级键:在 include 之后合并(覆盖已 include 的值)
  • 嵌套 include:支持最多 10 层深度
  • 相对路径:相对于包含它的文件解析
  • OpenClaw 所有的写入:当一次写入只更改一个顶级 section,且该 section 由单文件 include 支持,例如 plugins: { $include: "./plugins.json5" },OpenClaw 会更新该被 include 的文件,并保持 openclaw.json 不变
  • 不支持的写穿透:root include、include 数组,以及带有同级覆盖的 include,在 OpenClaw 所有的写入中会失败关闭,而不是展平配置
  • 限制范围$include 路径必须解析到保存 openclaw.json 的目录下。若要跨机器或用户共享一棵目录树,请将 OPENCLAW_INCLUDE_ROOTS 设置为路径列表(POSIX 上为 :,Windows 上为 ;),其中包含 include 可引用的其他目录。符号链接会被解析并重新检查,因此即使某个路径在字面上位于配置目录中,但其真实目标逃逸出每个允许的 root,仍会被拒绝。
  • 错误处理:对缺失文件、解析错误和循环 include 提供清晰错误

配置热重载

Gateway 网关会监视 ~/.openclaw/openclaw.json 并自动应用更改 — 大多数设置无需手动重启。 直接文件编辑在通过验证前会被视为不受信任。监视器会等待编辑器临时写入/重命名抖动稳定,读取最终文件,并在不重写 openclaw.json 的情况下拒绝无效外部编辑。OpenClaw 所有的配置写入在写入前使用同一个 schema gate;破坏性覆盖(例如删除 gateway.mode 或将文件缩小超过一半)会被拒绝,并保存为 .rejected.* 以供检查。 如果看到 config reload skipped (invalid config),或启动时报出 Invalid config,请检查配置,运行 openclaw config validate,然后运行 openclaw doctor --fix 进行修复。请参阅 Gateway 网关故障排除查看检查清单。

重载模式

模式行为
hybrid(默认)立即热应用安全更改。对关键更改自动重启。
hot仅热应用安全更改。需要重启时记录警告 — 由你处理。
restart对任何配置更改都重启 Gateway 网关,无论是否安全。
off禁用文件监视。更改会在下次手动重启时生效。
{
  gateway: {
    reload: { mode: "hybrid", debounceMs: 300 },
  },
}

哪些会热应用,哪些需要重启

大多数字段可以无停机热应用。在 hybrid 模式下,需要重启的更改会被自动处理。
类别字段需要重启?
渠道channels.*web(WhatsApp)— 所有内置和插件渠道
智能体和模型agentagentsmodelsrouting
自动化hookscronagent.heartbeat
会话和消息sessionmessages
工具和媒体toolsbrowserskillsmcpaudiotalk
UI 和其他uiloggingidentitybindings
Gateway 网关服务器gateway.*(端口、绑定、认证、tailscale、TLS、HTTP)
基础设施discoverycanvasHostplugins
gateway.reloadgateway.remote 是例外 — 更改它们不会触发重启。

重载规划

当你编辑通过 $include 引用的源文件时,OpenClaw 会从源作者编写的布局规划重新加载,而不是从扁平化的内存视图规划。这样即使单个顶层部分位于自己的 include 文件中,例如 plugins: { $include: "./plugins.json5" },也能让热重载决策(热应用还是重启)保持可预测。如果源布局存在歧义,重新加载规划会以关闭方式失败。

配置 RPC(程序化更新)

对于通过 Gateway 网关 API 写入配置的工具,建议使用以下流程:
  • config.schema.lookup 用于检查一个子树(浅层 schema 节点 + 子项摘要)
  • config.get 用于获取当前快照以及 hash
  • config.patch 用于局部更新(JSON merge patch:对象合并,null 删除,数组替换)
  • 仅当你打算替换整个配置时才使用 config.apply
  • update.run 用于显式自更新并重启;当重启后的会话应运行一个后续轮次时,请包含 continuationMessage
  • update.status 用于检查最新的更新重启哨兵,并在重启后验证正在运行的版本
智能体应将 config.schema.lookup 视为获取精确字段级文档和约束的第一站。当需要更广泛的配置映射、默认值或专用子系统参考链接时,请使用 配置参考
控制平面写入(config.applyconfig.patchupdate.run)按每个 deviceId+clientIp 每 60 秒 3 个请求进行速率限制。重启请求会合并,然后在重启周期之间强制执行 30 秒冷却时间。update.status 是只读的,但属于管理员作用域,因为重启哨兵可能包含更新步骤摘要和命令输出尾部。
局部补丁示例:
openclaw gateway call config.get --params '{}'  # capture payload.hash
openclaw gateway call config.patch --params '{
  "raw": "{ channels: { telegram: { groups: { \"*\": { requireMention: false } } } } }",
  "baseHash": "<hash>"
}'
config.applyconfig.patch 都接受 rawbaseHashsessionKeynoterestartDelayMs。当配置已经存在时,这两个方法都要求提供 baseHash

环境变量

OpenClaw 会从父进程读取环境变量,并额外读取:
  • 当前工作目录中的 .env(如果存在)
  • ~/.openclaw/.env(全局回退)
两个文件都不会覆盖现有环境变量。你也可以在配置中设置内联环境变量:
{
  env: {
    OPENROUTER_API_KEY: "sk-or-...",
    vars: { GROQ_API_KEY: "gsk-..." },
  },
}
如果启用且预期键名未设置,OpenClaw 会运行你的登录 shell,并只导入缺失的键:
{
  env: {
    shellEnv: { enabled: true, timeoutMs: 15000 },
  },
}
环境变量等价项:OPENCLAW_LOAD_SHELL_ENV=1
在任何配置字符串值中使用 ${VAR_NAME} 引用环境变量:
{
  gateway: { auth: { token: "${OPENCLAW_GATEWAY_TOKEN}" } },
  models: { providers: { custom: { apiKey: "${CUSTOM_API_KEY}" } } },
}
规则:
  • 仅匹配大写名称:[A-Z_][A-Z0-9_]*
  • 缺失或为空的变量会在加载时抛出错误
  • 使用 $${VAR} 转义以输出字面量
  • 可在 $include 文件内工作
  • 内联替换:"${BASE}/v1""https://api.example.com/v1"
对于支持 SecretRef 对象的字段,你可以使用:
{
  models: {
    providers: {
      openai: { apiKey: { source: "env", provider: "default", id: "OPENAI_API_KEY" } },
    },
  },
  skills: {
    entries: {
      "image-lab": {
        apiKey: {
          source: "file",
          provider: "filemain",
          id: "/skills/entries/image-lab/apiKey",
        },
      },
    },
  },
  channels: {
    googlechat: {
      serviceAccountRef: {
        source: "exec",
        provider: "vault",
        id: "channels/googlechat/serviceAccount",
      },
    },
  },
}
SecretRef 详情(包括用于 env/file/execsecrets.providers)见 Secrets Management。支持的凭证路径列在 SecretRef Credential Surface 中。
完整优先级和来源请参阅 Environment

完整参考

如需完整的逐字段参考,请参阅 配置参考
相关:Configuration Examples · 配置参考 · Doctor

相关