模型 CLI
請參閱 /concepts/model-failover 了解 Auth Profile 輪替、冷卻時間,以及如何與後備互動。 快速 Provider 概覽 + 範例:/concepts/model-providers。模型選擇的運作方式
OpenClaw 依此順序選擇模型:- 主要模型(
agents.defaults.model.primary或agents.defaults.model)。 agents.defaults.model.fallbacks中的後備(依序)。- Provider 驗證故障移轉發生在 Provider 內部,然後才移至下一個模型。
agents.defaults.models是 OpenClaw 可以使用的模型允許清單/目錄(加上別名)。agents.defaults.imageModel僅在主要模型無法接受映像時使用。- 每個 Agent 的預設值可以透過
agents.list[].model加上繫結覆寫agents.defaults.model(請參閱 /concepts/multi-agent)。
快速模型策略
- 將您的主要設定為您可用的最強最新一代模型。
- 使用後備處理對成本/延遲敏感的任務和較低風險的聊天。
- 對於工具啟用的 Agent 或不受信任的輸入,避免使用較舊/較弱的模型層。
設定精靈(建議)
如果您不想手動編輯設定,請執行引導精靈:claude setup-token)。
設定金鑰(概覽)
agents.defaults.model.primary和agents.defaults.model.fallbacksagents.defaults.imageModel.primary和agents.defaults.imageModel.fallbacksagents.defaults.models(允許清單 + 別名 + Provider 參數)models.providers(寫入models.json的自訂 Provider)
z.ai/* 正規化為 zai/*。
Provider 設定範例(包括 OpenCode)位於
/gateway/configuration。
「模型不被允許」(以及回覆為何停止)
如果設定了agents.defaults.models,它會成為 /model 和對話覆寫的允許清單。當使用者選擇不在該允許清單中的模型時,OpenClaw 回傳:
- 將模型新增到
agents.defaults.models,或 - 清除允許清單(移除
agents.defaults.models),或 - 從
/model list選擇模型。
在聊天中切換模型(/model)
您可以在不重新啟動的情況下切換目前對話的模型:
/model(和/model list)是緊湊的、帶編號的選取器(模型系列 + 可用 Provider)。- 在 Discord 上,
/model和/models開啟帶有 Provider 和模型下拉選單及提交步驟的互動式選取器。 /model <#>從該選取器中選取。/model status是詳細視圖(驗證候選者,以及設定時的 Provider 端點baseUrl+api模式)。- 模型引用透過在第一個
/上分割來解析。輸入/model <ref>時請使用provider/model。 - 如果模型 ID 本身包含
/(OpenRouter 樣式),您必須包含 Provider 前置詞(範例:/model openrouter/moonshotai/kimi-k2)。 - 如果您省略 Provider,OpenClaw 將輸入視為別名或預設 Provider 的模型(只有當模型 ID 中沒有
/時才有效)。
CLI 指令
openclaw models(沒有子指令)是 models status 的捷徑。
models list
預設顯示已設定的模型。實用旗標:
--all:完整目錄--local:僅限本機 Provider--provider <name>:按 Provider 篩選--plain:每行一個模型--json:機器可讀輸出
models status
顯示已解析的主要模型、後備、映像模型,以及已設定 Provider 的驗證概覽。它也會顯示在驗證儲存中找到的設定檔的 OAuth 到期狀態(預設在 24 小時內警告)。--plain 只列印已解析的主要模型。
OAuth 狀態始終顯示(並包含在 --json 輸出中)。如果已設定的 Provider 沒有憑證,models status 會列印缺少驗證區段。
JSON 包含 auth.oauth(警告視窗 + 設定檔)和 auth.providers(每個 Provider 的有效驗證)。
使用 --check 進行自動化(缺少/過期時退出 1,即將過期時退出 2)。
驗證選擇取決於 Provider/帳號。對於始終開啟的 Gateway 主機,API 金鑰通常是最可預測的;也支援訂閱 Token 流程。
範例(Anthropic setup-token):
掃描(OpenRouter 免費模型)
openclaw models scan 檢查 OpenRouter 的免費模型目錄,並可以選擇性地探測模型的工具和映像支援。
主要旗標:
--no-probe:跳過即時探針(僅限元資料)--min-params <b>:最小參數大小(十億)--max-age-days <days>:跳過較舊的模型--provider <name>:Provider 前置詞篩選--max-candidates <n>:後備列表大小--set-default:將agents.defaults.model.primary設定為第一個選擇--set-image:將agents.defaults.imageModel.primary設定為第一個映像選擇
OPENROUTER_API_KEY)。沒有金鑰時,使用 --no-probe 只列出候選者。
掃描結果按以下排名:
- 映像支援
- 工具延遲
- 上下文大小
- 參數數量
- OpenRouter
/models列表(篩選:free) - 需要來自 Auth Profile 或
OPENROUTER_API_KEY的 OpenRouter API 金鑰(請參閱 /environment) - 選用篩選:
--max-age-days、--min-params、--provider、--max-candidates - 探針控制:
--timeout、--concurrency
--yes 以接受預設值。
模型登錄(models.json)
models.providers 中的自訂 Provider 被寫入 Agent 目錄下的 models.json(預設 ~/.openclaw/agents/<agentId>/agent/models.json)。除非 models.mode 設定為 replace,否則預設合併此檔案。
匹配 Provider ID 的合併模式優先順序:
- Agent
models.json中已存在的非空baseUrl優先。 - 只有當該 Provider 在目前設定/Auth Profile 上下文中不受 SecretRef 管理時,Agent
models.json中的非空apiKey才優先。 - SecretRef 管理的 Provider
apiKey值從來源標記(env 引用的ENV_VAR_NAME,file/exec 引用的secretref-managed)重新整理,而非持久化已解析的機密。 - SecretRef 管理的 Provider 標頭值從來源標記(env 引用的
secretref-env:ENV_VAR_NAME,file/exec 引用的secretref-managed)重新整理。 - 空的或遺失的 Agent
apiKey/baseUrl後退到設定models.providers。 - 其他 Provider 欄位從設定和正規化的目錄資料重新整理。
models.json 的任何時候,包括指令驅動的路徑如 openclaw agent。