Multi-agent

Instradamento multi-agente

Status: active

Esegui più agenti isolati: ciascuno con il proprio workspace, la propria directory di stato (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.

I profili di autenticazione sono per agente. Ogni agente legge dal proprio:

text
~/.openclaw/agents/<agentId>/agent/auth-profiles.json

Le Skills vengono caricate dal workspace di ogni agente più radici condivise come ~/.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.

Percorsi (mappa rapida)

  • Configurazione: ~/.openclaw/openclaw.json (o OPENCLAW_CONFIG_PATH)
  • Directory di stato: ~/.openclaw (o OPENCLAW_STATE_DIR)
  • Workspace: ~/.openclaw/workspace (o ~/.openclaw/workspace-<agentId>)
  • Directory agente: ~/.openclaw/agents/<agentId>/agent (o agents.list[].agentDir)
  • Sessioni: ~/.openclaw/agents/<agentId>/sessions

Modalità agente singolo (predefinita)

Se non fai nulla, OpenClaw esegue un singolo agente:

  • agentId è predefinito a main.
  • Le sessioni hanno chiave agent:main:<mainKey>.
  • Il workspace è predefinito a ~/.openclaw/workspace (o ~/.openclaw/workspace-<profile> quando OPENCLAW_PROFILE è impostato).
  • Lo stato è predefinito a ~/.openclaw/agents/main/agent.

Helper agente

Usa la procedura guidata degli agenti per aggiungere un nuovo agente isolato:

bash
openclaw agents add work

Quindi aggiungi bindings (o lascia che lo faccia la procedura guidata) per instradare i messaggi in ingresso.

Verifica con:

bash
openclaw agents list --bindings

Avvio rapido

  • Create each agent workspace

    Usa la procedura guidata o crea i workspace manualmente:

    bash
    openclaw agents add codingopenclaw agents add social

    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:

    • 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.
    bash
    openclaw channels login --channel whatsapp --account work

    Vedi le guide dei canali: Discord, Telegram, WhatsApp.

  • Add agents, accounts, and bindings

    Aggiungi agenti sotto agents.list, account di canale sotto channels.<channel>.accounts e collegali con bindings (esempi sotto).

  • Restart and verify

    bash
    openclaw gateway restartopenclaw agents list --bindingsopenclaw channels status --probe
  • Più agenti = più persone, più personalità

    Con più agenti, ogni agentId diventa una persona completamente isolata:

    • Numeri di telefono/account diversi (per canale accountId).
    • Personalità diverse (file del workspace per agente come AGENTS.md e SOUL.md).
    • Autenticazione + sessioni separate (nessuna comunicazione incrociata salvo abilitazione esplicita).

    Questo consente a più persone di condividere un server Gateway mantenendo isolati i loro "cervelli" IA e i dati.

    Ricerca di memoria QMD tra agenti

    Se un agente deve cercare nelle trascrizioni di sessione QMD di un altro agente, aggiungi raccolte extra sotto agents.list[].memorySearch.qmd.extraCollections. Usa agents.defaults.memorySearch.qmd.extraCollections solo quando ogni agente deve ereditare le stesse raccolte di trascrizioni condivise.

    json5
    {  agents: {    defaults: {      workspace: "~/workspaces/main",      memorySearch: {        qmd: {          extraCollections: [{ path: "~/agents/family/sessions", name: "family-sessions" }],        },      },    },    list: [      {        id: "main",        workspace: "~/workspaces/main",        memorySearch: {          qmd: {            extraCollections: [{ path: "notes" }], // resolves inside workspace -> collection named "notes-main"          },        },      },      { id: "family", workspace: "~/workspaces/family" },    ],  },  memory: {    backend: "qmd",    qmd: { includeDefaultMemory: false },  },}

    Il percorso della raccolta extra può essere condiviso tra agenti, ma il nome della raccolta resta esplicito quando il percorso è fuori dal workspace dell'agente. I percorsi dentro il workspace restano delimitati all'agente, così ogni agente mantiene il proprio insieme di ricerca nelle trascrizioni.

    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).

    Esempio:

    json5
    {  agents: {    list: [      { id: "alex", workspace: "~/.openclaw/workspace-alex" },      { id: "mia", workspace: "~/.openclaw/workspace-mia" },    ],  },  bindings: [    {      agentId: "alex",      match: { channel: "whatsapp", peer: { kind: "direct", id: "+15551230001" } },    },    {      agentId: "mia",      match: { channel: "whatsapp", peer: { kind: "direct", id: "+15551230002" } },    },  ],  channels: {    whatsapp: {      dmPolicy: "allowlist",      allowFrom: ["+15551230001", "+15551230002"],    },  },}

    Note:

    • 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:

  • peer match

    ID esatto di DM/gruppo/canale.

  • parentPeer match

    Ereditarietà del thread.

  • guildId + roles

    Routing per ruolo Discord.

  • guildId

    Discord.

  • teamId

    Slack.

  • accountId match for a channel

    Fallback per account.

  • Channel-level match

    accountId: "*".

  • Default agent

    Fallback a agents.list[].default, altrimenti prima voce dell'elenco, predefinito: main.

  • 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 (semantica AND).
    Account-scope detail
    • Un binding che omette accountId corrisponde 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) usano accountId 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, imessage
    • irc, line, googlechat, mattermost, matrix, nextcloud-talk
    • zalo, 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 un agentId tramite (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

    Ogni account bot Discord corrisponde a un accountId univoco. Collega ogni account a un agente e mantieni allowlist per bot.

    json5
    {  agents: {    list: [      { id: "main", workspace: "~/.openclaw/workspace-main" },      { id: "coding", workspace: "~/.openclaw/workspace-coding" },    ],  },  bindings: [    { agentId: "main", match: { channel: "discord", accountId: "default" } },    { agentId: "coding", match: { channel: "discord", accountId: "coding" } },  ],  channels: {    discord: {      groupPolicy: "allowlist",      accounts: {        default: {          token: "DISCORD_BOT_TOKEN_MAIN",          guilds: {            "123456789012345678": {              channels: {                "222222222222222222": { allow: true, requireMention: false },              },            },          },        },        coding: {          token: "DISCORD_BOT_TOKEN_CODING",          guilds: {            "123456789012345678": {              channels: {                "333333333333333333": { allow: true, requireMention: false },              },            },          },        },      },    },  },}
    • Invita ogni bot nel guild e abilita Message Content Intent.
    • I token risiedono in channels.discord.accounts.<id>.token (l’account predefinito può usare DISCORD_BOT_TOKEN).
    Bot Telegram per agente
    json5
    {  agents: {    list: [      { id: "main", workspace: "~/.openclaw/workspace-main" },      { id: "alerts", workspace: "~/.openclaw/workspace-alerts" },    ],  },  bindings: [    { agentId: "main", match: { channel: "telegram", accountId: "default" } },    { agentId: "alerts", match: { channel: "telegram", accountId: "alerts" } },  ],  channels: {    telegram: {      accounts: {        default: {          botToken: "123456:ABC...",          dmPolicy: "pairing",        },        alerts: {          botToken: "987654:XYZ...",          dmPolicy: "allowlist",          allowFrom: ["tg:123456789"],        },      },    },  },}
    • Crea un bot per agente con BotFather e copia ogni token.
    • I token risiedono in channels.telegram.accounts.<id>.botToken (l’account predefinito può usare TELEGRAM_BOT_TOKEN).
    Numeri WhatsApp per agente

    Collega ogni account prima di avviare il Gateway:

    bash
    openclaw channels login --channel whatsapp --account personalopenclaw channels login --channel whatsapp --account biz

    ~/.openclaw/openclaw.json (JSON5):

    js
    {  agents: {    list: [      {        id: "home",        default: true,        name: "Home",        workspace: "~/.openclaw/workspace-home",        agentDir: "~/.openclaw/agents/home/agent",      },      {        id: "work",        name: "Work",        workspace: "~/.openclaw/workspace-work",        agentDir: "~/.openclaw/agents/work/agent",      },    ],  },   // Deterministic routing: first match wins (most-specific first).  bindings: [    { agentId: "home", match: { channel: "whatsapp", accountId: "personal" } },    { agentId: "work", match: { channel: "whatsapp", accountId: "biz" } },     // Optional per-peer override (example: send a specific group to work agent).    {      agentId: "work",      match: {        channel: "whatsapp",        accountId: "personal",        peer: { kind: "group", id: "[email protected]" },      },    },  ],   // Off by default: agent-to-agent messaging must be explicitly enabled + allowlisted.  tools: {    agentToAgent: {      enabled: false,      allow: ["home", "work"],    },  },   channels: {    whatsapp: {      accounts: {        personal: {          // Optional override. Default: ~/.openclaw/credentials/whatsapp/personal          // authDir: "~/.openclaw/credentials/whatsapp/personal",        },        biz: {          // Optional override. Default: ~/.openclaw/credentials/whatsapp/biz          // authDir: "~/.openclaw/credentials/whatsapp/biz",        },      },    },  },}

    Pattern comuni

    Uso quotidiano su WhatsApp + lavoro approfondito su Telegram

    Dividi per canale: instrada WhatsApp a un agente veloce per l’uso quotidiano e Telegram a un agente Opus.

    json5
    {  agents: {    list: [      {        id: "chat",        name: "Everyday",        workspace: "~/.openclaw/workspace-chat",        model: "anthropic/claude-sonnet-4-6",      },      {        id: "opus",        name: "Deep Work",        workspace: "~/.openclaw/workspace-opus",        model: "anthropic/claude-opus-4-6",      },    ],  },  bindings: [    { agentId: "chat", match: { channel: "whatsapp" } },    { agentId: "opus", match: { channel: "telegram" } },  ],}

    Note:

    • Se hai più account per un canale, aggiungi accountId al binding (ad esempio { channel: "whatsapp", accountId: "personal" }).
    • Per instradare un singolo DM/gruppo a Opus mantenendo il resto su chat, aggiungi un binding match.peer per quel peer; le corrispondenze peer hanno sempre la precedenza sulle regole per l’intero canale.

    Stesso canale, un peer verso Opus

    Mantieni WhatsApp sull’agente veloce, ma instrada un DM a Opus:

    json5
    {  agents: {    list: [      {        id: "chat",        name: "Everyday",        workspace: "~/.openclaw/workspace-chat",        model: "anthropic/claude-sonnet-4-6",      },      {        id: "opus",        name: "Deep Work",        workspace: "~/.openclaw/workspace-opus",        model: "anthropic/claude-opus-4-6",      },    ],  },  bindings: [    {      agentId: "opus",      match: { channel: "whatsapp", peer: { kind: "direct", id: "+15551234567" } },    },    { agentId: "chat", match: { channel: "whatsapp" } },  ],}

    I binding peer hanno sempre la precedenza, quindi tienili sopra la regola per l’intero canale.

    Agente famiglia associato a un gruppo WhatsApp

    Associa un agente dedicato alla famiglia a un singolo gruppo WhatsApp, con controllo tramite menzione e una policy degli strumenti più restrittiva:

    json5
    {  agents: {    list: [      {        id: "family",        name: "Family",        workspace: "~/.openclaw/workspace-family",        identity: { name: "Family Bot" },        groupChat: {          mentionPatterns: ["@family", "@familybot", "@Family Bot"],        },        sandbox: {          mode: "all",          scope: "agent",        },        tools: {          allow: [            "exec",            "read",            "sessions_list",            "sessions_history",            "sessions_send",            "sessions_spawn",            "session_status",          ],          deny: ["write", "edit", "apply_patch", "browser", "canvas", "nodes", "cron"],        },      },    ],  },  bindings: [    {      agentId: "family",      match: {        channel: "whatsapp",        peer: { kind: "group", id: "[email protected]" },      },    },  ],}

    Note:

    • Gli elenchi di strumenti allow/deny sono strumenti, non Skills. Se una skill deve eseguire un binario, assicurati che exec sia consentito e che il binario esista nella sandbox.
    • Per un controllo più restrittivo, imposta agents.list[].groupChat.mentionPatterns e mantieni abilitate le allowlist dei gruppi per il canale.

    Configurazione di sandbox e strumenti per agente

    Ogni agente può avere la propria sandbox e le proprie restrizioni sugli strumenti:

    js
    {  agents: {    list: [      {        id: "personal",        workspace: "~/.openclaw/workspace-personal",        sandbox: {          mode: "off",  // No sandbox for personal agent        },        // No tool restrictions - all tools available      },      {        id: "family",        workspace: "~/.openclaw/workspace-family",        sandbox: {          mode: "all",     // Always sandboxed          scope: "agent",  // One container per agent          docker: {            // Optional one-time setup after container creation            setupCommand: "apt-get update && apt-get install -y git curl",          },        },        tools: {          allow: ["read"],                    // Only read tool          deny: ["exec", "write", "edit", "apply_patch"],    // Deny others        },      },    ],  },}

    Vantaggi:

    • 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.

    Consulta Sandbox e strumenti multi-agente per esempi dettagliati.

    Correlati

    Was this useful?