Multi-agent

Routering voor meerdere agents

Status: active

Voer meerdere geïsoleerde agents uit — elk met een eigen werkruimte, statusmap (agentDir) en sessiegeschiedenis — plus meerdere kanaalaccounts (bijv. twee WhatsApps) in één draaiende Gateway. Inkomende berichten worden via bindings naar de juiste agent gerouteerd.

Een agent is hier de volledige scope per persona: werkruimtebestanden, auth-profielen, modelregister en sessieopslag. agentDir is de statusmap op schijf die deze configuratie per agent bevat op ~/.openclaw/agents/<agentId>/. Een binding koppelt een kanaalaccount (bijv. een Slack-werkruimte of een WhatsApp-nummer) aan een van die agents.

Wat is "één agent"?

Een agent is een volledig afgebakend brein met een eigen:

  • Werkruimte (bestanden, AGENTS.md/SOUL.md/USER.md, lokale notities, persona-regels).
  • Statusmap (agentDir) voor auth-profielen, modelregister en configuratie per agent.
  • Sessieopslag (chatgeschiedenis + routeringsstatus) onder ~/.openclaw/agents/<agentId>/sessions.

Auth-profielen zijn per agent. Elke agent leest uit zijn eigen:

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

Skills worden geladen vanuit elke agentwerkruimte plus gedeelde roots zoals ~/.openclaw/skills, en daarna gefilterd op de effectieve allowlist voor agentskills wanneer die is geconfigureerd. Gebruik agents.defaults.skills voor een gedeelde basislijn en agents.list[].skills voor vervanging per agent. Zie Skills: per-agent vs gedeeld en Skills: allowlists voor agentskills.

De Gateway kan één agent (standaard) of veel agents naast elkaar hosten.

Paden (snelle kaart)

  • Configuratie: ~/.openclaw/openclaw.json (of OPENCLAW_CONFIG_PATH)
  • Statusmap: ~/.openclaw (of OPENCLAW_STATE_DIR)
  • Werkruimte: ~/.openclaw/workspace (of ~/.openclaw/workspace-<agentId>)
  • Agentmap: ~/.openclaw/agents/<agentId>/agent (of agents.list[].agentDir)
  • Sessies: ~/.openclaw/agents/<agentId>/sessions

Modus met één agent (standaard)

Als je niets doet, voert OpenClaw één agent uit:

  • agentId staat standaard op main.
  • Sessies worden gesleuteld als agent:main:<mainKey>.
  • Werkruimte staat standaard op ~/.openclaw/workspace (of ~/.openclaw/workspace-<profile> wanneer OPENCLAW_PROFILE is ingesteld).
  • Status staat standaard op ~/.openclaw/agents/main/agent.

Agent-helper

Gebruik de agent-wizard om een nieuwe geïsoleerde agent toe te voegen:

bash
openclaw agents add work

Voeg daarna bindings toe (of laat de wizard dat doen) om inkomende berichten te routeren.

Verifieer met:

bash
openclaw agents list --bindings

Snelle start

  • Maak elke agentwerkruimte aan

    Gebruik de wizard of maak werkruimten handmatig aan:

    bash
    openclaw agents add codingopenclaw agents add social

    Elke agent krijgt een eigen werkruimte met SOUL.md, AGENTS.md en optioneel USER.md, plus een toegewezen agentDir en sessieopslag onder ~/.openclaw/agents/<agentId>.

  • Maak kanaalaccounts aan

    Maak één account per agent aan op je voorkeurskanalen:

    • Discord: één bot per agent, schakel Message Content Intent in, kopieer elk token.
    • Telegram: één bot per agent via BotFather, kopieer elk token.
    • WhatsApp: koppel elk telefoonnummer per account.
    bash
    openclaw channels login --channel whatsapp --account work

    Zie kanaalgidsen: Discord, Telegram, WhatsApp.

  • Voeg agents, accounts en bindings toe

    Voeg agents toe onder agents.list, kanaalaccounts onder channels.<channel>.accounts, en verbind ze met bindings (voorbeelden hieronder).

  • Herstart en verifieer

    bash
    openclaw gateway restartopenclaw agents list --bindingsopenclaw channels status --probe
  • Meerdere agents = meerdere mensen, meerdere persoonlijkheden

    Met meerdere agents wordt elke agentId een volledig geïsoleerde persona:

    • Andere telefoonnummers/accounts (per kanaal accountId).
    • Andere persoonlijkheden (werkruimtebestanden per agent zoals AGENTS.md en SOUL.md).
    • Gescheiden auth + sessies (geen kruisverkeer tenzij expliciet ingeschakeld).

    Hiermee kunnen meerdere mensen één Gateway-server delen terwijl hun AI-"breinen" en gegevens geïsoleerd blijven.

    QMD-geheugenzoekopdracht tussen agents

    Als één agent de QMD-sessietranscripten van een andere agent moet doorzoeken, voeg dan extra collecties toe onder agents.list[].memorySearch.qmd.extraCollections. Gebruik agents.defaults.memorySearch.qmd.extraCollections alleen wanneer elke agent dezelfde gedeelde transcriptcollecties moet erven.

    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 },  },}

    Het pad naar de extra collectie kan tussen agents worden gedeeld, maar de collectienaam blijft expliciet wanneer het pad buiten de agentwerkruimte ligt. Paden binnen de werkruimte blijven agent-scoped, zodat elke agent zijn eigen set voor transcriptzoekopdrachten behoudt.

    Eén WhatsApp-nummer, meerdere mensen (DM-splitsing)

    Je kunt verschillende WhatsApp-DM's naar verschillende agents routeren terwijl je op één WhatsApp-account blijft. Match op E.164 van de afzender (zoals +15551234567) met peer.kind: "direct". Antwoorden komen nog steeds vanaf hetzelfde WhatsApp-nummer (geen afzenderidentiteit per agent).

    Voorbeeld:

    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"],    },  },}

    Notities:

    • DM-toegangscontrole is globaal per WhatsApp-account (koppeling/allowlist), niet per agent.
    • Voor gedeelde groepen bind je de groep aan één agent of gebruik je Broadcast-groepen.

    Routeringsregels (hoe berichten een agent kiezen)

    Bindings zijn deterministisch en meest specifiek wint:

  • peer-match

    Exacte DM-/groep-/kanaal-id.

  • parentPeer-match

    Thread-overerving.

  • guildId + rollen

    Discord-rolroutering.

  • guildId

    Discord.

  • teamId

    Slack.

  • accountId-match voor een kanaal

    Fallback per account.

  • Match op kanaalniveau

    accountId: "*".

  • Standaardagent

    Fallback naar agents.list[].default, anders het eerste lijstitem, standaard: main.

  • Tie-breaking en AND-semantiek
    • Als meerdere bindings in dezelfde laag matchen, wint de eerste in configuratievolgorde.
    • Als een binding meerdere matchvelden instelt (bijvoorbeeld peer + guildId), zijn alle opgegeven velden vereist (AND-semantiek).
    Detail van accountscope
    • Een binding die accountId weglaat, matcht alleen het standaardaccount.
    • Gebruik accountId: "*" voor een kanaalbrede fallback over alle accounts.
    • Als je later dezelfde binding voor dezelfde agent toevoegt met een expliciete account-id, werkt OpenClaw de bestaande kanaal-only binding bij naar account-scoped in plaats van deze te dupliceren.

    Meerdere accounts / telefoonnummers

    Kanalen die meerdere accounts ondersteunen (bijv. WhatsApp) gebruiken accountId om elke login te identificeren. Elke accountId kan naar een andere agent worden gerouteerd, zodat één server meerdere telefoonnummers kan hosten zonder sessies te mengen.

    Als je een kanaalbreed standaardaccount wilt wanneer accountId wordt weggelaten, stel dan channels.<channel>.defaultAccount in (optioneel). Wanneer dit niet is ingesteld, valt OpenClaw terug op default als dat aanwezig is, anders op de eerste geconfigureerde account-id (gesorteerd).

    Veelvoorkomende kanalen die dit patroon ondersteunen zijn:

    • whatsapp, telegram, discord, slack, signal, imessage
    • irc, line, googlechat, mattermost, matrix, nextcloud-talk
    • zalo, zalouser, nostr, feishu

    Concepten

    • agentId: één "brein" (werkruimte, auth per agent, sessieopslag per agent).
    • accountId: één kanaalaccountinstantie (bijv. WhatsApp-account "personal" versus "biz").
    • binding: routeert inkomende berichten naar een agentId via (channel, accountId, peer) en optioneel guild-/team-id's.
    • Directe chats vallen terug op agent:<agentId>:<mainKey> ("main" per agent; session.mainKey).

    Platformvoorbeelden

    Discord-bots per agent

    Elk Discord-botaccount wordt gekoppeld aan een unieke accountId. Bind elk account aan een agent en houd allowlists per bot bij.

    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 },              },            },          },        },      },    },  },}
    • Nodig elke bot uit voor de guild en schakel Message Content Intent in.
    • Tokens staan in channels.discord.accounts.<id>.token (standaardaccount kan DISCORD_BOT_TOKEN gebruiken).
    Telegram bots per agent
    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"],        },      },    },  },}
    • Maak één bot per agent met BotFather en kopieer elke token.
    • Tokens staan in channels.telegram.accounts.<id>.botToken (standaardaccount kan TELEGRAM_BOT_TOKEN gebruiken).
    WhatsApp numbers per agent

    Koppel elk account voordat je de Gateway start:

    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",        },      },    },  },}

    Veelvoorkomende patronen

    WhatsApp daily + Telegram deep work

    Splits op kanaal: routeer WhatsApp naar een snelle dagelijkse agent en Telegram naar een Opus-agent.

    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" } },  ],}

    Opmerkingen:

    • Als je meerdere accounts voor een kanaal hebt, voeg dan accountId toe aan de binding (bijvoorbeeld { channel: "whatsapp", accountId: "personal" }).
    • Om één DM/groep naar Opus te routeren terwijl de rest op chat blijft, voeg je een match.peer-binding toe voor die peer; peer-matches winnen altijd van kanaalbrede regels.

    Same channel, one peer to Opus

    Houd WhatsApp op de snelle agent, maar routeer één DM naar 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" } },  ],}

    Peer-bindingen winnen altijd, dus houd ze boven de kanaalbrede regel.

    Family agent bound to a WhatsApp group

    Bind een speciale familie-agent aan één WhatsApp-groep, met vermeldingsgating en een strikter toolbeleid:

    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]" },      },    },  ],}

    Opmerkingen:

    • Tool-allow/deny-lijsten zijn tools, geen skills. Als een skill een binary moet uitvoeren, zorg er dan voor dat exec is toegestaan en dat de binary in de sandbox bestaat.
    • Stel voor strengere gating agents.list[].groupChat.mentionPatterns in en houd groeps-allowlists ingeschakeld voor het kanaal.

    Sandbox- en toolconfiguratie per agent

    Elke agent kan zijn eigen sandbox- en toolbeperkingen hebben:

    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        },      },    ],  },}

    Voordelen:

    • Beveiligingsisolatie: beperk tools voor niet-vertrouwde agents.
    • Resourcebeheer: plaats specifieke agents in een sandbox terwijl andere op de host blijven.
    • Flexibel beleid: verschillende rechten per agent.

    Zie Multi-agent sandbox and tools voor gedetailleerde voorbeelden.

    Gerelateerd

    • ACP-agents — externe coding-harnassen uitvoeren
    • Kanaalroutering — hoe berichten naar agents worden gerouteerd
    • Aanwezigheid — aanwezigheid en beschikbaarheid van agents
    • Sessie — sessie-isolatie en routering
    • Sub-agents — agent-runs op de achtergrond starten
    Was this useful?