Esegui più agenti isolati: ciascuno con il proprio workspace, la propria directory di stato (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.
agentDir) e la propria cronologia di sessione, più più account di canale (ad esempio due WhatsApp) in un unico Gateway in esecuzione. I messaggi in ingresso vengono instradati all’agente corretto tramite binding.
Un agente qui è l’intero ambito per-persona: file del workspace, profili di autenticazione, registro dei modelli e archivio delle sessioni. agentDir è la directory di stato su disco che contiene questa configurazione per agente in ~/.openclaw/agents/<agentId>/. Un binding associa un account di canale (ad esempio un workspace Slack o un numero WhatsApp) a uno di questi agenti.
Che cos’è “un agente”?
Un agente è un cervello completamente delimitato con il proprio:- Workspace (file, AGENTS.md/SOUL.md/USER.md, note locali, regole della persona).
- Directory di stato (
agentDir) per profili di autenticazione, registro dei modelli e configurazione per agente. - Archivio delle sessioni (cronologia chat + stato di routing) sotto
~/.openclaw/agents/<agentId>/sessions.
sessions_history è anche qui il percorso più sicuro per il richiamo tra sessioni: restituisce una vista limitata e sanificata, non un dump grezzo della trascrizione. Il richiamo dell’assistente rimuove tag di ragionamento, scaffolding <relevant-memories>, payload XML di chiamate strumento in testo semplice (inclusi <tool_call>...</tool_call>, <function_call>...</function_call>, <tool_calls>...</tool_calls>, <function_calls>...</function_calls> e blocchi di chiamate strumento troncati), scaffolding di chiamate strumento degradato, token di controllo modello ASCII/full-width trapelati e XML di chiamate strumento MiniMax malformato prima della redazione/troncamento.~/.openclaw/skills, quindi filtrate dalla allowlist effettiva delle skill dell’agente quando configurata. Usa agents.defaults.skills per una base condivisa e agents.list[].skills per la sostituzione per agente. Vedi Skills: per agente rispetto a condivise e Skills: allowlist delle skill degli agenti.
Il Gateway può ospitare un agente (predefinito) o molti agenti affiancati.
Nota sul workspace: il workspace di ogni agente è la cwd predefinita, non una sandbox rigida. I percorsi relativi si risolvono dentro il workspace, ma i percorsi assoluti possono raggiungere altre posizioni dell’host a meno che il sandboxing non sia abilitato. Vedi Sandboxing.
Percorsi (mappa rapida)
- Configurazione:
~/.openclaw/openclaw.json(oOPENCLAW_CONFIG_PATH) - Directory di stato:
~/.openclaw(oOPENCLAW_STATE_DIR) - Workspace:
~/.openclaw/workspace(o~/.openclaw/workspace-<agentId>) - Directory agente:
~/.openclaw/agents/<agentId>/agent(oagents.list[].agentDir) - Sessioni:
~/.openclaw/agents/<agentId>/sessions
Modalità agente singolo (predefinita)
Se non fai nulla, OpenClaw esegue un singolo agente:agentIdè predefinito amain.- Le sessioni hanno chiave
agent:main:<mainKey>. - Il workspace è predefinito a
~/.openclaw/workspace(o~/.openclaw/workspace-<profile>quandoOPENCLAW_PROFILEè impostato). - Lo stato è predefinito a
~/.openclaw/agents/main/agent.
Helper agente
Usa la procedura guidata degli agenti per aggiungere un nuovo agente isolato:bindings (o lascia che lo faccia la procedura guidata) per instradare i messaggi in ingresso.
Verifica con:
Avvio rapido
Create each agent workspace
Usa la procedura guidata o crea i workspace manualmente:Ogni agente ottiene il proprio workspace con
SOUL.md, AGENTS.md e USER.md opzionale, più un agentDir dedicato e un archivio sessioni sotto ~/.openclaw/agents/<agentId>.Create channel accounts
Crea un account per agente sui tuoi canali preferiti:Vedi le guide dei canali: Discord, Telegram, WhatsApp.
- Discord: un bot per agente, abilita Message Content Intent, copia ogni token.
- Telegram: un bot per agente tramite BotFather, copia ogni token.
- WhatsApp: collega ogni numero di telefono per account.
Add agents, accounts, and bindings
Aggiungi agenti sotto
agents.list, account di canale sotto channels.<channel>.accounts e collegali con bindings (esempi sotto).Più agenti = più persone, più personalità
Con più agenti, ogniagentId diventa una persona completamente isolata:
- Numeri di telefono/account diversi (per canale
accountId). - Personalità diverse (file del workspace per agente come
AGENTS.mdeSOUL.md). - Autenticazione + sessioni separate (nessuna comunicazione incrociata salvo abilitazione esplicita).
Ricerca di memoria QMD tra agenti
Se un agente deve cercare nelle trascrizioni di sessione QMD di un altro agente, aggiungi raccolte extra sottoagents.list[].memorySearch.qmd.extraCollections. Usa agents.defaults.memorySearch.qmd.extraCollections solo quando ogni agente deve ereditare le stesse raccolte di trascrizioni condivise.
Un numero WhatsApp, più persone (divisione DM)
Puoi instradare DM WhatsApp diversi ad agenti diversi rimanendo su un solo account WhatsApp. Corrispondi al mittente E.164 (come+15551234567) con peer.kind: "direct". Le risposte arrivano comunque dallo stesso numero WhatsApp (nessuna identità mittente per agente).
Le chat dirette collassano nella chiave di sessione principale dell’agente, quindi il vero isolamento richiede un agente per persona.
- Il controllo di accesso ai DM è globale per account WhatsApp (abbinamento/allowlist), non per agente.
- Per gruppi condivisi, collega il gruppo a un agente oppure usa gruppi Broadcast.
Regole di routing (come i messaggi scelgono un agente)
I binding sono deterministici e vince il più specifico:Tie-breaking and AND semantics
Tie-breaking and AND semantics
- Se più binding corrispondono nello stesso livello, vince il primo nell’ordine della configurazione.
- Se un binding imposta più campi di match (per esempio
peer+guildId), tutti i campi specificati sono obbligatori (semanticaAND).
Account-scope detail
Account-scope detail
- Un binding che omette
accountIdcorrisponde solo all’account predefinito. - Usa
accountId: "*"per un fallback a livello di canale su tutti gli account. - Se in seguito aggiungi lo stesso binding per lo stesso agente con un ID account esplicito, OpenClaw aggiorna il binding esistente solo canale a delimitato all’account invece di duplicarlo.
Più account / numeri di telefono
I canali che supportano più account (ad esempio WhatsApp) usanoaccountId per identificare ogni accesso. Ogni accountId può essere instradato a un agente diverso, quindi un server può ospitare più numeri di telefono senza mescolare le sessioni.
Se vuoi un account predefinito a livello di canale quando accountId è omesso, imposta channels.<channel>.defaultAccount (opzionale). Quando non è impostato, OpenClaw ripiega su default se presente, altrimenti sul primo ID account configurato (ordinato).
Canali comuni che supportano questo modello includono:
whatsapp,telegram,discord,slack,signal,imessageirc,line,googlechat,mattermost,matrix,nextcloud-talkzalo,zalouser,nostr,feishu
Concetti
agentId: un “cervello” (workspace, autenticazione per agente, archivio sessioni per agente).accountId: un’istanza di account di canale (ad esempio account WhatsApp"personal"rispetto a"biz").binding: instrada messaggi in ingresso a unagentIdtramite(channel, accountId, peer)e opzionalmente ID guild/team.- Le chat dirette collassano in
agent:<agentId>:<mainKey>(“main” per agente;session.mainKey).
Esempi di piattaforma
Discord bots per agent
Discord bots per agent
Ogni account bot Discord corrisponde a un
accountId univoco. Collega ogni account a un agente e mantieni allowlist per bot.- Invita ogni bot nel guild e abilita Message Content Intent.
- I token risiedono in
channels.discord.accounts.<id>.token(l’account predefinito può usareDISCORD_BOT_TOKEN).
Bot Telegram per agente
Bot Telegram per agente
- Crea un bot per agente con BotFather e copia ogni token.
- I token risiedono in
channels.telegram.accounts.<id>.botToken(l’account predefinito può usareTELEGRAM_BOT_TOKEN).
Numeri WhatsApp per agente
Numeri WhatsApp per agente
Collega ogni account prima di avviare il Gateway:
~/.openclaw/openclaw.json (JSON5):Pattern comuni
- Uso quotidiano su WhatsApp + lavoro approfondito su Telegram
- Stesso canale, un peer verso Opus
- Agente famiglia associato a un gruppo WhatsApp
Dividi per canale: instrada WhatsApp a un agente veloce per l’uso quotidiano e Telegram a un agente Opus.Note:
- Se hai più account per un canale, aggiungi
accountIdal binding (ad esempio{ channel: "whatsapp", accountId: "personal" }). - Per instradare un singolo DM/gruppo a Opus mantenendo il resto su chat, aggiungi un binding
match.peerper quel peer; le corrispondenze peer hanno sempre la precedenza sulle regole per l’intero canale.
Configurazione di sandbox e strumenti per agente
Ogni agente può avere la propria sandbox e le proprie restrizioni sugli strumenti:setupCommand risiede sotto sandbox.docker e viene eseguito una volta alla creazione del container. Gli override sandbox.docker.* per agente vengono ignorati quando lo scope risolto è "shared".- Isolamento di sicurezza: limita gli strumenti per agenti non attendibili.
- Controllo delle risorse: esegui in sandbox agenti specifici mantenendo gli altri sull’host.
- Policy flessibili: autorizzazioni diverse per agente.
tools.elevated è globale e basato sul mittente; non è configurabile per agente. Se ti servono confini per agente, usa agents.list[].tools per negare exec. Per il targeting dei gruppi, usa agents.list[].groupChat.mentionPatterns in modo che le @menzioni mappino in modo pulito all’agente previsto.Correlati
- Agenti ACP — eseguire harness di codifica esterni
- Instradamento dei canali — come i messaggi vengono instradati agli agenti
- Presence — presenza e disponibilità degli agenti
- Session — isolamento e instradamento delle sessioni
- Sub-agents — generare esecuzioni di agenti in background