Multi-agent
Routering voor meerdere agenten
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. Binnenkomende berichten worden via bindingen 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:
~/.openclaw/agents/<agentId>/agent/auth-profiles.json
Skills worden geladen vanuit elke agentwerkruimte plus gedeelde roots zoals ~/.openclaw/skills, en daarna gefilterd op basis van de effectieve allowlist voor agent-Skills wanneer die is geconfigureerd. Gebruik agents.defaults.skills voor een gedeelde basis en agents.list[].skills voor vervanging per agent. Zie Skills: per-agent versus gedeeld en Skills: allowlists voor agent-Skills.
De Gateway kan één agent hosten (standaard) of veel agents naast elkaar.
Paden (snelle kaart)
- Configuratie:
~/.openclaw/openclaw.json(ofOPENCLAW_CONFIG_PATH) - Statusmap:
~/.openclaw(ofOPENCLAW_STATE_DIR) - Werkruimte:
~/.openclaw/workspace(of~/.openclaw/workspace-<agentId>) - Agentmap:
~/.openclaw/agents/<agentId>/agent(ofagents.list[].agentDir) - Sessies:
~/.openclaw/agents/<agentId>/sessions
Modus met één agent (standaard)
Als je niets doet, draait OpenClaw één agent:
agentIdwordt standaardmain.- Sessies worden gesleuteld als
agent:main:<mainKey>. - De werkruimte is standaard
~/.openclaw/workspace(of~/.openclaw/workspace-<profile>wanneerOPENCLAW_PROFILEis ingesteld). - De status is standaard
~/.openclaw/agents/main/agent.
Agenthulp
Gebruik de agentwizard om een nieuwe geïsoleerde agent toe te voegen:
openclaw agents add work
Voeg daarna bindings toe (of laat de wizard dat doen) om binnenkomende berichten te routeren.
Controleer met:
openclaw agents list --bindings
Snel aan de slag
Maak elke agentwerkruimte
Gebruik de wizard of maak werkruimten handmatig:
openclaw agents add coding
openclaw agents add social
Elke agent krijgt zijn eigen werkruimte met SOUL.md, AGENTS.md en optioneel USER.md, plus een eigen agentDir en sessieopslag onder ~/.openclaw/agents/<agentId>.
Maak kanaalaccounts
Maak één account per agent aan op je voorkeurskanalen:
- Discord: één bot per agent, schakel Message Content Intent in, kopieer elke token.
- Telegram: één bot per agent via BotFather, kopieer elke token.
- WhatsApp: koppel elk telefoonnummer per account.
openclaw channels login --channel whatsapp --account work
Voeg agents, accounts en bindingen toe
Voeg agents toe onder agents.list, kanaalaccounts onder channels.<channel>.accounts, en verbind ze met bindings (voorbeelden hieronder).
Herstart en controleer
openclaw gateway restart
openclaw agents list --bindings
openclaw channels status --probe
Meerdere agents = meerdere mensen, meerdere persoonlijkheden
Met meerdere agents wordt elke agentId een volledig geïsoleerde persona:
- Verschillende telefoonnummers/accounts (per kanaal
accountId). - Verschillende persoonlijkheden (werkruimtebestanden per agent zoals
AGENTS.mdenSOUL.md). - Gescheiden auth + sessies (geen kruisgesprekken tenzij expliciet ingeschakeld).
Zo 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.
{
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 extra collectiepad kan tussen agents worden gedeeld, maar de collectienaam blijft expliciet wanneer het pad buiten de agentwerkruimte ligt. Paden binnen de werkruimte blijven agentgebonden, 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 afzender in E.164-indeling (zoals +15551234567) met peer.kind: "direct". Antwoorden komen nog steeds vanaf hetzelfde WhatsApp-nummer (geen afzenderidentiteit per agent).
Voorbeeld:
{
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:
- Toegangscontrole voor DM's is globaal per WhatsApp-account (koppeling/allowlist), niet per agent.
- Voor gedeelde groepen bind je de groep aan één agent of gebruik je Uitzendgroepen.
Routeringsregels (hoe berichten een agent kiezen)
Bindingen 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 de eerste lijstvermelding, standaard: main.
Tie-breaking en AND-semantiek
- Als meerdere bindingen 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).
Details over accountscope
- Een binding die
accountIdweglaat, 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, upgradet OpenClaw de bestaande kanaal-only binding naar accountgebonden 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 die aanwezig is, anders op de eerste geconfigureerde account-id (gesorteerd).
Veelgebruikte kanalen die dit patroon ondersteunen zijn onder andere:
whatsapp,telegram,discord,slack,signal,imessageirc,line,googlechat,mattermost,matrix,nextcloud-talkbluebubbles,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 binnenkomende berichten naar eenagentIdop basis van(channel, accountId, peer)en optioneel guild-/team-id's.- Directe chats vallen samen tot
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.
{
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(het standaardaccount kanDISCORD_BOT_TOKENgebruiken).
Telegram-bots per agent
{
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 elk token.
- Tokens staan in
channels.telegram.accounts.<id>.botToken(het standaardaccount kanTELEGRAM_BOT_TOKENgebruiken).
WhatsApp-nummers per agent
Koppel elk account voordat je de gateway start:
openclaw channels login --channel whatsapp --account personal
openclaw channels login --channel whatsapp --account biz
~/.openclaw/openclaw.json (JSON5):
{
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 dagelijks + Telegram diep werk
Splits op kanaal: routeer WhatsApp naar een snelle alledaagse agent en Telegram naar een Opus-agent.
{
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" } },
],
}
Notities:
- Als je meerdere accounts voor een kanaal hebt, voeg dan
accountIdtoe 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.
Zelfde kanaal, één peer naar Opus
Houd WhatsApp op de snelle agent, maar routeer één DM naar Opus:
{
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 zet ze boven de kanaalbrede regel.
Familie-agent gebonden aan een WhatsApp-groep
Bind een speciale familie-agent aan één WhatsApp-groep, met vermeldingstoegang en een strikter toolsbeleid:
{
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]" },
},
},
],
}
Notities:
- Toestaan/weigeren-lijsten voor tools zijn tools, geen skills. Als een skill een binary moet uitvoeren, zorg er dan voor dat
execis toegestaan en dat de binary in de sandbox bestaat. - Stel voor strengere toegang
agents.list[].groupChat.mentionPatternsin en houd groepsallowlists ingeschakeld voor het kanaal.
Sandbox- en toolconfiguratie per agent
Elke agent kan zijn eigen sandbox en toolbeperkingen hebben:
{
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.
- Flexibele beleidsregels: verschillende machtigingen per agent.
Zie Sandbox en tools voor meerdere agents voor gedetailleerde voorbeelden.
Gerelateerd
- ACP-agents — externe codeharnassen uitvoeren
- Kanaalroutering — hoe berichten naar agents worden gerouteerd
- Aanwezigheid — aanwezigheid en beschikbaarheid van agents
- Sessie — sessie-isolatie en routering
- Sub-agents — achtergrondruns van agents starten