Voer meerdere geïsoleerde agents uit — elk met een eigen werkruimte, statusmap (Documentation Index
Fetch the complete documentation index at: https://docs2.openclaw.ai/llms.txt
Use this file to discover all available pages before exploring further.
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.
sessions_history is hier ook het veiligere pad voor herinnering tussen sessies: het retourneert een begrensde, opgeschoonde weergave, geen ruwe transcriptdump. Assistant-herinnering verwijdert denktags, <relevant-memories>-scaffolding, plattetekst-XML-payloads voor tool-aanroepen (inclusief <tool_call>...</tool_call>, <function_call>...</function_call>, <tool_calls>...</tool_calls>, <function_calls>...</function_calls> en afgekorte tool-aanroepblokken), gedegradeerde tool-aanroep-scaffolding, gelekte ASCII-/full-width-modelbesturingstokens en misvormde MiniMax-tool-aanroep-XML vóór redactie/afkapping.~/.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.
Werkruimtenotitie: de werkruimte van elke agent is de standaard cwd, geen harde sandbox. Relatieve paden worden binnen de werkruimte opgelost, maar absolute paden kunnen andere hostlocaties bereiken tenzij sandboxing is ingeschakeld. Zie Sandboxing.
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, voert OpenClaw één agent uit:agentIdstaat standaard opmain.- Sessies worden gesleuteld als
agent:main:<mainKey>. - Werkruimte staat standaard op
~/.openclaw/workspace(of~/.openclaw/workspace-<profile>wanneerOPENCLAW_PROFILEis ingesteld). - Status staat standaard op
~/.openclaw/agents/main/agent.
Agent-helper
Gebruik de agent-wizard om een nieuwe geïsoleerde agent toe te voegen:bindings toe (of laat de wizard dat doen) om inkomende berichten te routeren.
Verifieer met:
Snelle start
Maak elke agentwerkruimte aan
Gebruik de wizard of maak werkruimten handmatig aan: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
Voeg agents, accounts en bindings toe
Voeg agents toe onder
agents.list, kanaalaccounts onder channels.<channel>.accounts, en verbind ze met bindings (voorbeelden hieronder).Meerdere agents = meerdere mensen, meerdere persoonlijkheden
Met meerdere agents wordt elkeagentId een volledig geïsoleerde persona:
- Andere telefoonnummers/accounts (per kanaal
accountId). - Andere persoonlijkheden (werkruimtebestanden per agent zoals
AGENTS.mdenSOUL.md). - Gescheiden auth + sessies (geen kruisverkeer tenzij expliciet ingeschakeld).
QMD-geheugenzoekopdracht tussen agents
Als één agent de QMD-sessietranscripten van een andere agent moet doorzoeken, voeg dan extra collecties toe onderagents.list[].memorySearch.qmd.extraCollections. Gebruik agents.defaults.memorySearch.qmd.extraCollections alleen wanneer elke agent dezelfde gedeelde transcriptcollecties moet erven.
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).
Directe chats vallen terug op de hoofdsessiesleutel van de agent, dus echte isolatie vereist één agent per persoon.
- 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:Tie-breaking en AND-semantiek
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
Detail van 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, 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) gebruikenaccountId 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,imessageirc,line,googlechat,mattermost,matrix,nextcloud-talkzalo,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 eenagentIdvia(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
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.- Nodig elke bot uit voor de guild en schakel Message Content Intent in.
- Tokens staan in
channels.discord.accounts.<id>.token(standaardaccount kanDISCORD_BOT_TOKENgebruiken).
Telegram bots per agent
Telegram bots per agent
- Maak één bot per agent met BotFather en kopieer elke token.
- Tokens staan in
channels.telegram.accounts.<id>.botToken(standaardaccount kanTELEGRAM_BOT_TOKENgebruiken).
WhatsApp numbers per agent
WhatsApp numbers per agent
Koppel elk account voordat je de Gateway start:
~/.openclaw/openclaw.json (JSON5):Veelvoorkomende patronen
- WhatsApp daily + Telegram deep work
- Same channel, one peer to Opus
- Family agent bound to a WhatsApp group
Splits op kanaal: routeer WhatsApp naar een snelle dagelijkse agent en Telegram naar een Opus-agent.Opmerkingen:
- 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.
Sandbox- en toolconfiguratie per agent
Elke agent kan zijn eigen sandbox- en toolbeperkingen hebben:setupCommand staat onder sandbox.docker en wordt één keer uitgevoerd wanneer de container wordt aangemaakt. Overrides voor sandbox.docker.* per agent worden genegeerd wanneer de opgeloste scope "shared" is.- 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.
tools.elevated is globaal en gebaseerd op afzender; het is niet per agent configureerbaar. Als je grenzen per agent nodig hebt, gebruik dan agents.list[].tools om exec te weigeren. Gebruik voor groepstargeting agents.list[].groupChat.mentionPatterns zodat @vermeldingen netjes aan de bedoelde agent worden gekoppeld.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