Vai al contenuto principale

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.

Failover del modello

Rotazione dei profili di autenticazione, cooldown e interazione con i fallback.

Provider di modelli

Panoramica rapida dei provider ed esempi.

Runtime degli agenti

PI, Codex e altri runtime del ciclo degli agenti.

Riferimento di configurazione

Chiavi di configurazione del modello.
I riferimenti ai modelli scelgono un provider e un modello. Di solito non scelgono il runtime dell’agente di basso livello. I riferimenti agli agenti OpenAI sono l’eccezione principale: openai/gpt-5.5 viene eseguito tramite il runtime app-server di Codex per impostazione predefinita sul provider OpenAI ufficiale. Le sostituzioni esplicite del runtime appartengono alla policy di provider/modello, non all’intero agente o alla sessione. In modalità runtime Codex, il riferimento openai/gpt-* non implica la fatturazione tramite chiave API; l’autenticazione può provenire da un account Codex o da un profilo di autenticazione openai-codex. Consulta Runtime degli agenti.

Come funziona la selezione del modello

OpenClaw seleziona i modelli in questo ordine:
1

Modello primario

agents.defaults.model.primary (o agents.defaults.model).
2

Fallback

agents.defaults.model.fallbacks (in ordine).
3

Failover dell'autenticazione del provider

Il failover dell’autenticazione avviene all’interno di un provider prima di passare al modello successivo.
  • agents.defaults.models è l’allowlist/catalogo dei modelli che OpenClaw può usare (più gli alias). Usa voci provider/* per limitare i provider visibili mantenendo dinamica la discovery dei provider.
  • agents.defaults.imageModel viene usato solo quando il modello primario non può accettare immagini.
  • agents.defaults.pdfModel viene usato dallo strumento pdf. Se omesso, lo strumento ripiega su agents.defaults.imageModel, poi sul modello risolto della sessione/predefinito.
  • agents.defaults.imageGenerationModel viene usato dalla capacità condivisa di generazione immagini. Se omesso, image_generate può comunque inferire un provider predefinito supportato dall’autenticazione. Prova prima il provider predefinito corrente, poi i restanti provider registrati per la generazione immagini in ordine di ID provider. Se imposti un provider/modello specifico, configura anche l’autenticazione/chiave API di quel provider.
  • agents.defaults.musicGenerationModel viene usato dalla capacità condivisa di generazione musica. Se omesso, music_generate può comunque inferire un provider predefinito supportato dall’autenticazione. Prova prima il provider predefinito corrente, poi i restanti provider registrati per la generazione musica in ordine di ID provider. Se imposti un provider/modello specifico, configura anche l’autenticazione/chiave API di quel provider.
  • agents.defaults.videoGenerationModel viene usato dalla capacità condivisa di generazione video. Se omesso, video_generate può comunque inferire un provider predefinito supportato dall’autenticazione. Prova prima il provider predefinito corrente, poi i restanti provider registrati per la generazione video in ordine di ID provider. Se imposti un provider/modello specifico, configura anche l’autenticazione/chiave API di quel provider.
  • I valori predefiniti per agente possono sovrascrivere agents.defaults.model tramite agents.list[].model più i binding (vedi Instradamento multi-agente).

Origine della selezione e comportamento di fallback

Lo stesso provider/model può significare cose diverse a seconda della sua origine:
  • I valori predefiniti configurati (agents.defaults.model.primary e i primari specifici dell’agente) sono il normale punto di partenza e usano agents.defaults.model.fallbacks.
  • Le selezioni di fallback automatico sono stato di recupero temporaneo. Vengono memorizzate con modelOverrideSource: "auto" così i turni successivi possono continuare a usare la catena di fallback senza provare prima un primario già noto come non valido.
  • Le selezioni della sessione utente sono esatte. /model, il selettore di modelli, session_status(model=...) e sessions.patch memorizzano modelOverrideSource: "user"; se quel provider/modello selezionato non è raggiungibile, OpenClaw fallisce in modo visibile invece di passare a un altro modello configurato.
  • Cron --model / payload model è un primario per singolo job. Usa comunque i fallback configurati, a meno che il job non fornisca fallbacks espliciti nel payload (usa fallbacks: [] per un’esecuzione cron rigorosa).
  • I selettori CLI del modello predefinito e dell’allowlist rispettano models.mode: "replace" elencando models.providers.*.models espliciti invece di caricare l’intero catalogo integrato.
  • Il selettore modelli della UI di controllo chiede al Gateway la sua vista configurata dei modelli: agents.defaults.models quando presente, incluse le voci provider/* per l’intero provider, altrimenti models.providers.*.models espliciti più i provider con autenticazione utilizzabile. Il catalogo integrato completo è riservato alle viste di navigazione esplicite, come models.list con view: "all" o openclaw models list --all.

Policy rapida per i modelli

  • Imposta il primario sul modello di ultima generazione più potente a tua disposizione.
  • Usa i fallback per attività sensibili a costi/latenza e chat a basso rischio.
  • Per agenti con strumenti abilitati o input non attendibili, evita livelli di modello più vecchi/deboli.

Onboarding (consigliato)

Se non vuoi modificare la configurazione a mano, esegui l’onboarding:
openclaw onboard
Può configurare modello + autenticazione per provider comuni, inclusi OpenAI Code (Codex) subscription (OAuth) e Anthropic (chiave API o Claude CLI).

Chiavi di configurazione (panoramica)

  • agents.defaults.model.primary e agents.defaults.model.fallbacks
  • agents.defaults.imageModel.primary e agents.defaults.imageModel.fallbacks
  • agents.defaults.pdfModel.primary e agents.defaults.pdfModel.fallbacks
  • agents.defaults.imageGenerationModel.primary e agents.defaults.imageGenerationModel.fallbacks
  • agents.defaults.videoGenerationModel.primary e agents.defaults.videoGenerationModel.fallbacks
  • agents.defaults.models (allowlist + alias + parametri provider + voci provider dinamiche provider/*)
  • models.providers (provider personalizzati scritti in models.json)
I riferimenti ai modelli vengono normalizzati in minuscolo. Gli alias dei provider come z.ai/* vengono normalizzati in zai/*.Gli esempi di configurazione dei provider (incluso OpenCode) si trovano in OpenCode.

Modifiche sicure all’allowlist

Usa scritture additive quando aggiorni agents.defaults.models a mano:
openclaw config set agents.defaults.models '{"openai/gpt-5.4":{}}' --strict-json --merge
openclaw config set protegge le mappe di modelli/provider da sovrascritture accidentali. Un’assegnazione di oggetto semplice a agents.defaults.models, models.providers o models.providers.<id>.models viene rifiutata quando rimuoverebbe voci esistenti. Usa --merge per modifiche additive; usa --replace solo quando il valore fornito deve diventare il valore completo di destinazione.Anche la configurazione interattiva del provider e openclaw configure --section model uniscono le selezioni con ambito provider nell’allowlist esistente, quindi aggiungere Codex, Ollama o un altro provider non elimina voci di modello non correlate. Configure preserva un agents.defaults.model.primary esistente quando l’autenticazione del provider viene riapplicata. I comandi espliciti di impostazione del valore predefinito, come openclaw models auth login --provider <id> --set-default e openclaw models set <model>, sostituiscono comunque agents.defaults.model.primary.

”Il modello non è consentito” (e perché le risposte si fermano)

Se agents.defaults.models è impostato, diventa l’allowlist per /model e per le sostituzioni di sessione. Quando un utente seleziona un modello che non è in quell’allowlist, OpenClaw restituisce:
Model "provider/model" is not allowed. Use /models to list providers, or /models <provider> to list models.
Add it with: openclaw config set agents.defaults.models '{"provider/model":{}}' --strict-json --merge
Questo accade prima che venga generata una risposta normale, quindi il messaggio può dare l’impressione che “non abbia risposto”. La correzione consiste nel:
  • Aggiungere il modello a agents.defaults.models, oppure
  • Cancellare l’allowlist (rimuovere agents.defaults.models), oppure
  • Scegliere un modello da /model list.
Quando il comando rifiutato includeva una sostituzione del runtime, come /model openai/gpt-5.5 --runtime codex, correggi prima l’allowlist, poi riprova lo stesso comando /model ... --runtime .... Per l’esecuzione nativa Codex, il modello selezionato è comunque openai/gpt-5.5; il runtime codex seleziona l’harness e usa separatamente l’autenticazione Codex. Per i modelli locali/GGUF, memorizza nell’allowlist il riferimento completo con prefisso provider, per esempio ollama/gemma4:26b, lmstudio/Gemma4-26b-a4-it-gguf o il provider/modello esatto mostrato da openclaw models list --provider <provider>. I nomi di file locali semplici o i nomi visualizzati non sono sufficienti quando l’allowlist è attiva. Se vuoi limitare i provider senza elencare manualmente ogni modello, aggiungi voci provider/* a agents.defaults.models:
{
  agents: {
    defaults: {
      models: {
        "openai-codex/*": {},
        "vllm/*": {},
      },
    },
  },
}
Con questa policy, /model, /models e i selettori di modelli mostrano il catalogo scoperto solo per quei provider. I nuovi modelli dei provider selezionati possono comparire senza modificare l’allowlist. Le voci esatte provider/model possono essere combinate con voci provider/* quando ti serve un modello specifico di un altro provider. Esempio di configurazione allowlist:
{
  agents: {
    defaults: {
      model: { primary: "anthropic/claude-sonnet-4-6" },
      models: {
        "anthropic/claude-sonnet-4-6": { alias: "Sonnet" },
        "anthropic/claude-opus-4-6": { alias: "Opus" },
      },
    },
  },
}

Cambiare modello in chat (/model)

Puoi cambiare modello per la sessione corrente senza riavviare:
/model
/model list
/model 3
/model openai/gpt-5.4
/model status
  • /model (e /model list) è un selettore compatto e numerato (famiglia di modelli + provider disponibili).
  • Su Discord, /model e /models aprono un selettore interattivo con menu a discesa per provider e modello più un passaggio Submit.
  • Su Telegram, le selezioni del selettore /models hanno ambito di sessione; non modificano il valore predefinito persistente dell’agente in openclaw.json.
  • /models add è deprecato e ora restituisce un messaggio di deprecazione invece di registrare modelli dalla chat.
  • /model <#> seleziona da quel selettore.
  • /model persiste immediatamente la nuova selezione della sessione.
  • Se l’agente è inattivo, l’esecuzione successiva usa subito il nuovo modello.
  • Se un’esecuzione è già attiva, OpenClaw contrassegna un cambio live come in sospeso e riavvia nel nuovo modello solo in un punto di retry pulito.
  • Se l’attività degli strumenti o l’output della risposta è già iniziato, il cambio in sospeso può restare in coda fino a una successiva opportunità di retry o al turno utente successivo.
  • Un riferimento /model selezionato dall’utente è rigoroso per quella sessione: se il provider/modello selezionato non è raggiungibile, la risposta fallisce in modo visibile invece di rispondere silenziosamente da agents.defaults.model.fallbacks. Questo è diverso dai valori predefiniti configurati e dai primari dei job cron, che possono comunque usare catene di fallback.
  • /model status è la vista dettagliata (candidati di autenticazione e, quando configurati, endpoint provider baseUrl + modalità api).
  • I riferimenti dei modelli vengono analizzati dividendo sulla prima /. Usa provider/model quando digiti /model <ref>.
  • Se l’ID del modello contiene a sua volta / (stile OpenRouter), devi includere il prefisso del provider (esempio: /model openrouter/moonshotai/kimi-k2).
  • Se ometti il provider, OpenClaw risolve l’input in questo ordine:
    1. corrispondenza dell’alias
    2. corrispondenza univoca del provider configurato per quell’esatto ID modello senza prefisso
    3. fallback deprecato al provider predefinito configurato — se quel provider non espone più il modello predefinito configurato, OpenClaw ripiega invece sul primo provider/modello configurato per evitare di mostrare un valore predefinito obsoleto di un provider rimosso.
Comportamento/configurazione completa dei comandi: Comandi slash.

Comandi CLI

openclaw models list
openclaw models status
openclaw models set <provider/model>
openclaw models set-image <provider/model>

openclaw models aliases list
openclaw models aliases add <alias> <provider/model>
openclaw models aliases remove <alias>

openclaw models fallbacks list
openclaw models fallbacks add <provider/model>
openclaw models fallbacks remove <provider/model>
openclaw models fallbacks clear

openclaw models image-fallbacks list
openclaw models image-fallbacks add <provider/model>
openclaw models image-fallbacks remove <provider/model>
openclaw models image-fallbacks clear
openclaw models (senza sottocomando) è una scorciatoia per models status.

models list

Mostra per impostazione predefinita i modelli configurati/con autenticazione disponibile. Flag utili:
--all
boolean
Catalogo completo. Include le righe del catalogo statico in bundle posseduto dal provider prima che l’autenticazione sia configurata, così le viste di sola scoperta possono mostrare modelli non disponibili finché non aggiungi le credenziali del provider corrispondenti.
--local
boolean
Solo provider locali.
--provider <id>
string
Filtra per ID provider, per esempio moonshot. Le etichette visualizzate dai selettori interattivi non sono accettate.
--plain
boolean
Un modello per riga.
--json
boolean
Output leggibile dalla macchina.

models status

Mostra il modello primario risolto, i fallback, il modello immagine e una panoramica dell’autenticazione dei provider configurati. Mostra anche lo stato di scadenza OAuth per i profili trovati nell’archivio autenticazione (avvisa entro 24 ore per impostazione predefinita). --plain stampa solo il modello primario risolto.
  • Lo stato OAuth viene sempre mostrato (e incluso nell’output --json). Se un provider configurato non ha credenziali, models status stampa una sezione Autenticazione mancante.
  • JSON include auth.oauth (finestra di avviso + profili) e auth.providers (autenticazione effettiva per provider, comprese le credenziali basate su env). auth.oauth riguarda solo la salute dei profili dell’archivio autenticazione; i provider solo-env non compaiono lì.
  • Usa --check per l’automazione (uscita 1 quando mancante/scaduto, 2 quando in scadenza).
  • Usa --probe per controlli di autenticazione live; le righe di probe possono provenire da profili di autenticazione, credenziali env o models.json.
  • Se auth.order.<provider> esplicito omette un profilo memorizzato, il probe segnala excluded_by_auth_order invece di provarlo. Se l’autenticazione esiste ma non è possibile risolvere alcun modello probeable per quel provider, il probe segnala status: no_model.
La scelta dell’autenticazione dipende da provider/account. Per host Gateway sempre attivi, le chiavi API sono solitamente le più prevedibili; sono supportati anche il riutilizzo di Claude CLI e i profili OAuth/token Anthropic esistenti.
Esempio (Claude CLI):
claude auth login
openclaw models status

Scansione (modelli gratuiti OpenRouter)

openclaw models scan ispeziona il catalogo dei modelli gratuiti di OpenRouter e può opzionalmente effettuare probe dei modelli per il supporto di strumenti e immagini.
--no-probe
boolean
Salta i probe live (solo metadati).
--min-params <b>
number
Dimensione minima dei parametri (miliardi).
--max-age-days <days>
number
Salta i modelli più vecchi.
--provider <name>
string
Filtro per prefisso provider.
--max-candidates <n>
number
Dimensione dell’elenco di fallback.
--set-default
boolean
Imposta agents.defaults.model.primary sulla prima selezione.
--set-image
boolean
Imposta agents.defaults.imageModel.primary sulla prima selezione immagine.
Il catalogo /models di OpenRouter è pubblico, quindi le scansioni di soli metadati possono elencare candidati gratuiti senza una chiave. Probe e inferenza richiedono comunque una chiave API OpenRouter (da profili di autenticazione o OPENROUTER_API_KEY). Se non è disponibile alcuna chiave, openclaw models scan ripiega sull’output di soli metadati e lascia invariata la configurazione. Usa --no-probe per richiedere esplicitamente la modalità solo metadati.
I risultati della scansione sono ordinati per:
  1. Supporto immagini
  2. Latenza strumenti
  3. Dimensione del contesto
  4. Numero di parametri
Input:
  • Elenco /models di OpenRouter (filtro :free)
  • I probe live richiedono una chiave API OpenRouter dai profili di autenticazione o OPENROUTER_API_KEY (vedi Variabili d’ambiente)
  • Filtri opzionali: --max-age-days, --min-params, --provider, --max-candidates
  • Controlli di richiesta/probe: --timeout, --concurrency
Quando i probe live vengono eseguiti in una TUI, puoi selezionare i fallback in modo interattivo. In modalità non interattiva, passa --yes per accettare i valori predefiniti. I risultati solo metadati sono informativi; --set-default e --set-image richiedono probe live così OpenClaw non configura un modello OpenRouter senza chiave inutilizzabile.

Registro modelli (models.json)

I provider personalizzati in models.providers vengono scritti in models.json sotto la directory dell’agente (predefinita ~/.openclaw/agents/<agentId>/agent/models.json). Questo file viene unito per impostazione predefinita, a meno che models.mode non sia impostato su replace.
Precedenza della modalità di merge per ID provider corrispondenti:
  • Vince il baseUrl non vuoto già presente nel models.json dell’agente.
  • La apiKey non vuota nel models.json dell’agente vince solo quando quel provider non è gestito da SecretRef nel contesto della configurazione/profilo di autenticazione corrente.
  • I valori apiKey del provider gestito da SecretRef vengono aggiornati dai marker sorgente (ENV_VAR_NAME per riferimenti env, secretref-managed per riferimenti file/exec) invece di persistere i segreti risolti.
  • I valori header del provider gestito da SecretRef vengono aggiornati dai marker sorgente (secretref-env:ENV_VAR_NAME per riferimenti env, secretref-managed per riferimenti file/exec).
  • apiKey/baseUrl dell’agente vuoti o mancanti ripiegano su models.providers della configurazione.
  • Gli altri campi provider vengono aggiornati dalla configurazione e dai dati normalizzati del catalogo.
La persistenza dei marker è autoritativa rispetto alla sorgente: OpenClaw scrive i marker dallo snapshot della configurazione sorgente attiva (prima della risoluzione), non dai valori dei segreti runtime risolti. Questo vale ogni volta che OpenClaw rigenera models.json, inclusi i percorsi guidati da comandi come openclaw agent.

Correlati