跳轉到主要內容

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 擁有的寫入不支援符號連結的 openclaw.json 配置;原子寫入可能會取代該路徑,而不是保留符號連結。如果你將設定保存在 預設狀態目錄之外,請將 OPENCLAW_CONFIG_PATH 直接指向實際檔案。 如果檔案不存在,OpenClaw 會使用安全的預設值。新增設定的常見原因:
  • 連接頻道並控制誰可以傳訊息給機器人
  • 設定模型、工具、沙箱或自動化(cron、hooks)
  • 調整工作階段、媒體、網路或 UI
請參閱完整參考以了解所有可用欄位。 Agent 和自動化在編輯設定前,應使用 config.schema.lookup 取得精確的欄位層級 文件。此頁面提供以任務為導向的指南;設定參考則提供更完整的 欄位地圖與預設值。
剛開始設定? 請從 openclaw onboard 開始進行互動式設定,或查看設定範例指南以取得可完整複製貼上的設定。

最小設定

// ~/.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 分支傳遞。執行階段 plugin 和頻道 schema 會在 manifest registry 載入時合併。 驗證失敗時:
  • Gateway 不會啟動
  • 只有診斷指令可用(openclaw doctoropenclaw logsopenclaw healthopenclaw status
  • 執行 openclaw doctor 以查看確切問題
  • 執行 openclaw doctor --fix(或 --yes)以套用修復
Gateway 會在每次成功啟動後保留一份受信任的最後已知良好副本。 如果 openclaw.json 稍後驗證失敗(或移除 gateway.mode、大幅縮小, 或前面被加上一行意外的記錄),OpenClaw 會將損壞的檔案保留為 .clobbered.*,還原最後已知良好副本,並記錄復原原因。 下一次 agent 回合也會收到系統事件警告,讓主要 agent 不會盲目重寫已還原的設定。當候選設定包含已遮蔽的秘密佔位符(例如 ***)時, 會略過提升為最後已知良好副本。 當所有驗證問題都限定在 plugins.entries.<id>... 範圍內時,OpenClaw 不會執行整個檔案的復原。它會保持目前設定作用中,並 呈現 plugin 本地失敗,避免 plugin schema 或主機版本不相容 回復無關的使用者設定。

常見任務

每個頻道在 channels.<provider> 下都有自己的設定區段。請參閱專屬頻道頁面取得設定步驟:所有頻道都共用相同的 DM 政策模式:
{
  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 控制逐字稿/工具圖片縮小(預設 1200);較低的值通常可降低大量截圖執行中的 vision token 使用量。
  • 請參閱模型 CLI 以了解如何在聊天中切換模型,並參閱模型容錯移轉 以了解驗證輪替與備援行為。
  • 對於自訂/自託管提供者,請參閱參考中的自訂提供者
DM 存取權會透過 dmPolicy 依頻道控制:
  • "pairing"(預設):未知傳送者會取得一次性配對代碼以供核准
  • "allowlist":只允許 allowFrom 中的傳送者(或已配對允許儲存中的傳送者)
  • "open":允許所有傳入 DM(需要 allowFrom: ["*"]
  • "disabled":忽略所有 DM
對於群組,請使用 groupPolicy + groupAllowFrom 或頻道特定允許清單。請參閱完整參考以了解每個頻道的詳細資訊。
群組訊息預設為需要提及。依 agent 設定觸發模式,並讓可見聊天室回覆維持在預設的訊息工具路徑,除非你刻意想要舊版自動最終回覆:
{
  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 中的安全 regex 模式
  • 可見回覆messages.visibleReplies 可以全域要求透過訊息工具傳送;messages.groupChat.visibleReplies 會覆寫群組/頻道的設定。
  • 請參閱完整參考以了解可見回覆模式、每個頻道覆寫,以及自我聊天模式。
使用 agents.defaults.skills 作為共用基準,然後用 agents.list[].skills 覆寫特定 agent:
{
  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,可針對單一頻道或帳號停用自動重新啟動,而不停用全域監控。
  • 請參閱健康檢查以進行操作除錯,並參閱完整參考以了解所有欄位。
讓本機用戶端在負載較高或低效能主機上,有更多時間完成驗證前的 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
      },
    },
  },
}
先建置映像:scripts/sandbox-setup.sh請參閱沙箱化以取得完整指南,並參閱完整參考以了解所有選項。
中繼支援的推播是在 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 不需要整個部署共用的中繼權杖。
  • 將每個中繼支援的註冊繫結到 iOS 應用程式配對的 Gateway 身分,讓另一個 Gateway 無法重複使用已儲存的註冊。
  • 讓本機/手動 iOS 組建維持直接使用 APNs。中繼支援的傳送只適用於透過中繼註冊的官方發佈組建。
  • 必須符合內建於官方/TestFlight iOS 組建中的中繼基礎 URL,讓註冊與傳送流量到達同一個中繼部署。
端到端流程:
  1. 安裝使用相同中繼基礎 URL 編譯的官方/TestFlight iOS 組建。
  2. 在 Gateway 上設定 gateway.push.apns.relay.baseUrl
  3. 將 iOS 應用程式配對到 Gateway,並讓節點與操作者工作階段都連線。
  4. iOS 應用程式擷取 Gateway 身分,使用 App Attest 加上應用程式收據向中繼註冊,然後將中繼支援的 push.apns.register 承載發佈到已配對的 Gateway。
  5. Gateway 儲存中繼控制代碼與傳送授權,接著將它們用於 push.test、喚醒提醒,以及重新連線喚醒。
作業注意事項:
  • 如果你將 iOS 應用程式切換到不同的 Gateway,請重新連線應用程式,讓它可以發佈繫結到該 Gateway 的新中繼註冊。
  • 如果你發佈指向不同中繼部署的新 iOS 組建,應用程式會重新整理其快取的中繼註冊,而不是重複使用舊的中繼來源。
相容性注意事項:
  • OPENCLAW_APNS_RELAY_BASE_URLOPENCLAW_APNS_RELAY_TIMEOUT_MS 仍可作為暫時的環境覆寫。
  • OPENCLAW_APNS_RELAY_ALLOW_HTTP=true 仍是僅限 loopback 的開發用例外途徑;請勿在設定中保留 HTTP 中繼 URL。
請參閱 iOS 應用程式了解端到端流程,並參閱驗證與信任流程了解中繼安全模型。
{
  agents: {
    defaults: {
      heartbeat: {
        every: "30m",
        target: "last",
      },
    },
  },
}
  • every: 持續時間字串(30m2h)。設定為 0m 即可停用。
  • target: last | none | <channel-id>(例如 discordmatrixtelegramwhatsapp
  • directPolicy: 對於 DM 樣式的 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 權杖。
  • Hook 驗證僅限標頭(Authorization: Bearer ...x-openclaw-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" } },
  ],
}
請參閱多代理程式完整參考,了解繫結規則與每個代理程式的存取設定檔。
使用 $include 組織大型設定:
// ~/.openclaw/openclaw.json
{
  gateway: { port: 18789 },
  agents: { $include: "./agents.json5" },
  broadcast: {
    $include: ["./clients/a.json5", "./clients/b.json5"],
  },
}
  • 單一檔案:取代包含它的物件
  • 檔案陣列:依序深度合併(後者優先)
  • 同層鍵:在 include 之後合併(覆寫已 include 的值)
  • 巢狀 include:最多支援 10 層深度
  • 相對路徑:相對於執行 include 的檔案解析
  • OpenClaw 管理的寫入:當寫入只變更由單一檔案 include 支援的一個頂層區段時, 例如 plugins: { $include: "./plugins.json5" }, OpenClaw 會更新該已 include 的檔案,並保持 openclaw.json 不變
  • 不支援的穿透寫入:根 include、include 陣列,以及含有同層覆寫的 include, 對 OpenClaw 管理的寫入會封閉失敗, 而不是攤平設定
  • 錯誤處理:針對遺失檔案、剖析錯誤與循環 include 提供清楚錯誤

設定熱重載

Gateway 會監看 ~/.openclaw/openclaw.json,並自動套用變更,大多數設定不需要手動重新啟動。 直接檔案編輯在通過驗證前會被視為不受信任。監看器會等待 編輯器暫存寫入/重新命名變動穩定下來,讀取最終檔案,並透過還原 最後已知良好設定來拒絕無效的外部編輯。OpenClaw 管理的 設定寫入在寫入前會使用相同的結構描述閘門;破壞性的覆寫, 例如移除 gateway.mode 或將檔案縮小超過一半,都會被拒絕 並儲存為 .rejected.* 供檢查。 Plugin 本機驗證失敗是例外:如果所有問題都位於 plugins.entries.<id>... 底下,重新載入會保留目前設定並回報 Plugin 問題,而不是還原 .last-good 如果你在記錄中看到 Config auto-restored from last-known-goodconfig reload restored last-known-good config,請檢查 openclaw.json 旁邊相符的 .clobbered.* 檔案,修正被拒絕的承載,然後執行 openclaw config validate。請參閱 Gateway 疑難排解 以取得復原檢查清單。

重新載入模式

模式行為
hybrid(預設)立即熱套用安全變更。對關鍵變更自動重新啟動。
hot只熱套用安全變更。需要重新啟動時會記錄警告,由你處理。
restart對任何設定變更重新啟動 Gateway,不論是否安全。
off停用檔案監看。變更會在下一次手動重新啟動時生效。
{
  gateway: {
    reload: { mode: "hybrid", debounceMs: 300 },
  },
}

哪些會熱套用,哪些需要重新啟動

大多數欄位可在不中斷服務的情況下熱套用。在 hybrid 模式中,需要重新啟動的變更會自動處理。
類別欄位需要重新啟動?
頻道channels.*, web (WhatsApp) — 所有內建與 Plugin 頻道
代理程式與模型agent, agents, models, routing
自動化hooks, cron, agent.heartbeat
工作階段與訊息session, messages
工具與媒體tools, browser, skills, mcp, audio, talk
UI 與雜項ui, logging, identity, bindings
Gateway 伺服器gateway.*(port、bind、auth、Tailscale、TLS、HTTP)
基礎架構discovery, canvasHost, plugins
gateway.reloadgateway.remote 是例外,變更它們不會觸發重新啟動。

重新載入規劃

當你編輯透過 $include 參照的來源檔案時,OpenClaw 會從來源撰寫的版面配置規劃重新載入,而不是從扁平化的記憶體內視圖規劃。即使單一頂層區段位於自己的引入檔案中,例如 plugins: { $include: "./plugins.json5" },這也能讓熱重新載入決策(熱套用或重新啟動)保持可預測。如果來源版面配置不明確,重新載入規劃會以封閉失敗處理。

設定 RPC(程式化更新)

對於透過 Gateway API 寫入設定的工具,建議使用此流程:
  • config.schema.lookup 用於檢查單一子樹(淺層 schema 節點 + 子項摘要)
  • config.get 用於擷取目前的快照與 hash
  • config.patch 用於部分更新(JSON merge patch:物件合併、null 刪除、陣列取代)
  • config.apply 僅在你打算取代整個設定時使用
  • update.run 用於明確自我更新並重新啟動
  • update.status 用於檢查最新的更新重新啟動哨兵,並在重新啟動後驗證執行中的版本
Agents 應將 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 vars,另外也讀取:
  • 目前工作目錄中的 .env(如果存在)
  • ~/.openclaw/.env(全域備援)
兩個檔案都不會覆寫現有的 env vars。你也可以在設定中設定行內 env vars:
{
  env: {
    OPENROUTER_API_KEY: "sk-or-...",
    vars: { GROQ_API_KEY: "gsk-..." },
  },
}
如果已啟用且預期的金鑰未設定,OpenClaw 會執行你的登入 shell,並只匯入缺少的金鑰:
{
  env: {
    shellEnv: { enabled: true, timeoutMs: 15000 },
  },
}
等效 env var:OPENCLAW_LOAD_SHELL_ENV=1
在任何設定字串值中使用 ${VAR_NAME} 參照 env vars:
{
  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)位於密鑰管理。支援的憑證路徑列於 SecretRef 憑證介面
請參閱環境,了解完整的優先順序與來源。

完整參考

如需完整的逐欄位參考,請參閱**設定參考**。
相關:設定範例 · 設定參考 · 診斷

相關