跳转到主要内容

配置

OpenClaw 从 ~/.openclaw/openclaw.json 读取可选的 配置。 如果文件缺失,OpenClaw 会使用安全的默认值。添加配置的常见原因:
  • 连接频道并控制谁可以向机器人发送消息
  • 设置模型、工具、沙箱隔离 或自动化 (cron, hooks)
  • 调整会话、媒体、网络或 UI
有关每个可用字段,请参阅完整参考
刚开始接触配置? 请从 openclaw onboard 开始进行交互式设置,或者查看配置示例指南以获取完整的复制粘贴配置。

最小配置

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

编辑配置

openclaw onboard       # full onboarding flow
openclaw configure     # config wizard

严格验证

OpenClaw 仅接受完全符合模式的配置。未知的键、格式错误的类型或无效的值会导致 Gateway(网关) 拒绝启动。唯一的根级例外是 $schema(字符串),以便编辑器可以附加 JSON 模式元数据。
验证失败时:
  • Gateway 无法启动
  • 只有诊断命令有效 (openclaw doctor, openclaw logs, openclaw health, openclaw status)
  • 运行 openclaw doctor 以查看确切的问题
  • 运行 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.2"],
      },
      models: {
        "anthropic/claude-sonnet-4-6": { alias: "Sonnet" },
        "openai/gpt-5.2": { alias: "GPT" },
      },
    },
  },
}
  • agents.defaults.models 定义模型目录并充当 /model 的允许列表。
  • 模型引用使用 provider/model 格式(例如 anthropic/claude-opus-4-6)。
  • agents.defaults.imageMaxDimensionPx 控制转录/工具图像的下采样(默认 1200);较低的值通常会在截图密集的运行中减少视觉令牌的使用。
  • 有关在聊天中切换模型的信息,请参阅 Models CLI;有关身份验证轮换和备用行为的信息,请参阅 Model Failover
  • 对于自定义/自托管提供商,请参阅参考文档中的 Custom providers
私信访问权限通过 dmPolicy 针对每个渠道进行控制:
  • "pairing"(默认):未知发送者将获得一次性配对代码以供审批
  • "allowlist":仅允许 allowFrom 中的发送者(或已配对的允许存储)
  • "open":允许所有传入的私信(需要 allowFrom: ["*"]
  • "disabled":忽略所有私信
对于群组,请使用 groupPolicy + groupAllowFrom 或特定于渠道的允许列表。有关每个渠道的详细信息,请参阅完整参考
群组消息默认为需要提及。为每个代理配置模式:
{
  agents: {
    list: [
      {
        id: "main",
        groupChat: {
          mentionPatterns: ["@openclaw", "openclaw"],
        },
      },
    ],
  },
  channels: {
    whatsapp: {
      groups: { "*": { requireMention: true } },
    },
  },
}
  • 元数据提及:原生 @-提及(WhatsApp 点击提及、Telegram @bot 等)
  • 文本模式mentionPatterns 中的安全正则表达式模式
  • 有关每个渠道的覆盖项和自聊模式,请参阅完整参考
控制网关以多强的力度重启看似停滞的渠道:
{
  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 可在不禁用全局监控的情况下为单个渠道或账户禁用自动重启。
  • 有关运营调试,请参阅健康检查;有关所有字段,请参阅完整参考
在隔离的 Docker 容器中运行代理会话:
{
  agents: {
    defaults: {
      sandbox: {
        mode: "non-main",  // off | non-main | all
        scope: "agent",    // session | agent | shared
      },
    },
  },
}
首先构建镜像:scripts/sandbox-setup.sh请参阅 沙箱隔离 以获取完整指南,并参阅 完整参考 了解所有选项。
基于中继的推送在 openclaw.json 中配置。在网关配置中设置此项:
{
  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
此配置的作用:
  • 允许网关通过外部中继发送 push.test、唤醒提醒以及重连唤醒。
  • 使用配对的 iOS 应用转发的注册范围发送授权。网关不需要部署范围的中继令牌。
  • 将每个基于中继的注册绑定到 iOS 应用配对的网关身份,因此另一个网关无法重用存储的注册。
  • 使本地/手动 iOS 版本保持使用直接 APNs。基于中继的发送仅适用于通过中继注册的官方分发版本。
  • 必须与植入官方/TestFlight iOS 版本中的中继基础 URL 匹配,以便注册和发送流量到达同一个中继部署。
端到端流程:
  1. 安装使用相同中继基础 URL 编译的官方/TestFlight iOS 版本。
  2. 在网关上配置 gateway.push.apns.relay.baseUrl
  3. 将 iOS 应用配对到网关,并让节点和操作员会话都连接。
  4. iOS 应用获取网关身份,使用 App Attest 和应用收据向中继注册,然后将基于中继的 push.apns.register 负载发布到配对的网关。
  5. 网关存储中继句柄和发送授权,然后将它们用于 push.test、唤醒提醒和重连唤醒。
操作说明:
  • 如果将 iOS 应用切换到不同的网关,请重新连接应用,以便其可以发布绑定到该网关的新中继注册。
  • 如果发布指向不同中继部署的新 iOS 版本,应用将刷新其缓存的中继注册,而不是重用旧的中继源。
兼容性说明:
  • OPENCLAW_APNS_RELAY_BASE_URLOPENCLAW_APNS_RELAY_TIMEOUT_MS 仍可用作临时环境变量覆盖。
  • OPENCLAW_APNS_RELAY_ALLOW_HTTP=true 仍然是仅限环回的开发逃生口;请勿在配置中保留 HTTP 中继 URL。
请参阅 iOS 应用 了解端到端流程,并参阅 身份验证和信任流程 了解中继安全模型。
{
  agents: {
    defaults: {
      heartbeat: {
        every: "30m",
        target: "last",
      },
    },
  },
}
  • every:持续时间字符串(30m2h)。设置为 0m 以禁用。
  • targetlast | whatsapp | telegram | discord | none
  • directPolicyallow(默认)或 block,用于私信风格的心跳目标
  • 有关完整指南,请参阅心跳
{
  cron: {
    enabled: true,
    maxConcurrentRuns: 2,
    sessionRetention: "24h",
    runLog: {
      maxBytes: "2mb",
      keepLines: 2000,
    },
  },
}
  • sessionRetention:从 sessions.json 中清理已完成的隔离运行会话(默认 24h;设置为 false 以禁用)。
  • runLog:根据大小和保留行数清理 cron/runs/<jobId>.jsonl
  • 有关功能概述和 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.gmail.allowUnsafeExternalContenthooks.mappings[].allowUnsafeExternalContent),除非进行严格范围的调试。
  • 对于由 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" } },
  ],
}
参见 多代理完整参考 了解绑定规则和每个代理的访问配置文件。
使用 $include 来组织大型配置:
// ~/.openclaw/openclaw.json
{
  gateway: { port: 18789 },
  agents: { $include: "./agents.json5" },
  broadcast: {
    $include: ["./clients/a.json5", "./clients/b.json5"],
  },
}
  • 单文件:替换包含的对象
  • 文件数组:按顺序深度合并(后者覆盖前者)
  • 兄弟键:在包含之后合并(覆盖包含的值)
  • 嵌套包含:最多支持 10 层深度
  • 相对路径:相对于包含文件解析
  • 错误处理:针对文件丢失、解析错误和循环包含提供清晰错误

配置热重载

Gateway(网关) 会监视 ~/.openclaw/openclaw.json 并自动应用更改 — 大多数设置无需手动重启。

重载模式

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

热应用内容 vs 需要重启的内容

大多数字段可以在不中断服务的情况下热应用。在 hybrid 模式下,需要重启的更改会自动处理。
类别字段需要重启?
频道channels.*, web (WhatsApp) — 所有内置和扩展频道
代理和模型agent, agents, models, routing
自动化hooks, cron, agent.heartbeat
会话与消息session, messages
工具与媒体tools, browser, skills, audio, talk
界面及其他ui, logging, identity, bindings
Gateway(网关) 服务器gateway.* (端口、绑定、认证、Tailscale、TLS、HTTP)
基础设施discovery, canvasHost, plugins
gateway.reloadgateway.remote 是例外情况 —— 更改它们不会触发重启。

配置 RPC (程序化更新)

控制平面写入 RPC (config.apply, config.patch, update.run) 的速率限制为每个 deviceId+clientIp 60 秒内 3 个请求。受到限制时,RPC 返回 UNAVAILABLE 并附带 retryAfterMs
验证 + 写入完整配置并在一步内重启 Gateway(网关)。
config.apply 将替换整个配置。请使用 config.patch 进行部分更新,或使用 openclaw config set 更新单个键。
参数:
  • raw (字符串) — 整个配置的 JSON5 载荷
  • baseHash (可选) — 来自 config.get 的配置哈希 (配置存在时必需)
  • sessionKey (可选) — 重启后唤醒 ping 的会话密钥
  • note (可选) — 重启哨兵的备注
  • restartDelayMs (可选) — 重启前的延迟 (默认 2000)
当某个重启请求已在处理中时,重启请求会被合并,且重启周期之间应用 30 秒的冷却时间。
openclaw gateway call config.get --params '{}'  # capture payload.hash
openclaw gateway call config.apply --params '{
  "raw": "{ agents: { defaults: { workspace: \"~/.openclaw/workspace\" } } }",
  "baseHash": "<hash>",
  "sessionKey": "agent:main:whatsapp:direct:+15555550123"
}'
将部分更新合并到现有配置(JSON 合并补丁语义)中:
  • 对象递归合并
  • null 删除一个键
  • 数组替换
参数:
  • raw (string) — 仅包含要更改键的 JSON5
  • baseHash (required) — 来自 config.get 的配置哈希
  • sessionKey, note, restartDelayMs — 同 config.apply
重启行为与 config.apply 匹配:合并待处理的重启,并在重启周期之间有 30 秒的冷却时间。
openclaw gateway call config.patch --params '{
  "raw": "{ channels: { telegram: { groups: { \"*\": { requireMention: false } } } } }",
  "baseHash": "<hash>"
}'

环境变量

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 详情(包括 secrets.providers 用于 env/file/exec)位于 Secrets 管理。 支持的凭证路径列在 SecretRef 凭证范围 中。
有关完整的优先级和来源,请参阅 Environment

完整参考

有关完整的逐字段参考,请参阅 配置参考
相关:配置示例 · 配置参考 · Doctor
本页面源自 openclaw/openclaw,由 BeaversLab 翻译,遵循 MIT 协议 发布。
Last modified on March 27, 2026