실행 중인 하나의 Gateway에서 여러 격리된 에이전트(각각 자체 워크스페이스, 상태 디렉터리(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), 세션 기록 포함)와 여러 채널 계정(예: WhatsApp 두 개)을 실행합니다. 인바운드 메시지는 바인딩을 통해 올바른 에이전트로 라우팅됩니다.
여기서 에이전트는 워크스페이스 파일, 인증 프로필, 모델 레지스트리, 세션 저장소를 포함하는 전체 페르소나별 범위입니다. agentDir은 이 에이전트별 구성을 ~/.openclaw/agents/<agentId>/에 보관하는 온디스크 상태 디렉터리입니다. 바인딩은 채널 계정(예: Slack 워크스페이스 또는 WhatsApp 번호)을 이러한 에이전트 중 하나에 매핑합니다.
”하나의 에이전트”란 무엇인가요?
에이전트는 자체 범위를 완전히 갖춘 두뇌이며 다음을 포함합니다.- 워크스페이스(파일, AGENTS.md/SOUL.md/USER.md, 로컬 노트, 페르소나 규칙).
- 인증 프로필, 모델 레지스트리, 에이전트별 구성을 위한 상태 디렉터리(
agentDir). ~/.openclaw/agents/<agentId>/sessions아래의 세션 저장소(채팅 기록 + 라우팅 상태).
여기에서도
sessions_history가 더 안전한 크로스 세션 회상 경로입니다. 원시 트랜스크립트 덤프가 아니라 제한되고 정리된 뷰를 반환합니다. Assistant 회상은 수정/잘라내기 전에 thinking 태그, <relevant-memories> 스캐폴딩, 일반 텍스트 도구 호출 XML 페이로드(<tool_call>...</tool_call>, <function_call>...</function_call>, <tool_calls>...</tool_calls>, <function_calls>...</function_calls>, 잘린 도구 호출 블록 포함), 다운그레이드된 도구 호출 스캐폴딩, 유출된 ASCII/전각 모델 제어 토큰, 잘못된 MiniMax 도구 호출 XML을 제거합니다.~/.openclaw/skills 같은 공유 루트에서 로드된 뒤, 구성된 경우 유효 에이전트 Skills 허용 목록으로 필터링됩니다. 공유 기준선에는 agents.defaults.skills를 사용하고 에이전트별 교체에는 agents.list[].skills를 사용하세요. Skills: 에이전트별 vs 공유 및 Skills: 에이전트 Skills 허용 목록을 참고하세요.
Gateway는 하나의 에이전트(기본값) 또는 여러 에이전트를 나란히 호스팅할 수 있습니다.
워크스페이스 참고: 각 에이전트의 워크스페이스는 기본 cwd이지 강제 샌드박스가 아닙니다. 상대 경로는 워크스페이스 안에서 해석되지만, 샌드박싱이 활성화되지 않은 경우 절대 경로는 다른 호스트 위치에 접근할 수 있습니다. 샌드박싱을 참고하세요.
경로(빠른 맵)
- 구성:
~/.openclaw/openclaw.json(또는OPENCLAW_CONFIG_PATH) - 상태 디렉터리:
~/.openclaw(또는OPENCLAW_STATE_DIR) - 워크스페이스:
~/.openclaw/workspace(또는~/.openclaw/workspace-<agentId>) - 에이전트 디렉터리:
~/.openclaw/agents/<agentId>/agent(또는agents.list[].agentDir) - 세션:
~/.openclaw/agents/<agentId>/sessions
단일 에이전트 모드(기본값)
아무 작업도 하지 않으면 OpenClaw는 단일 에이전트를 실행합니다.agentId의 기본값은 **main**입니다.- 세션 키는
agent:main:<mainKey>형식입니다. - 워크스페이스 기본값은
~/.openclaw/workspace입니다(OPENCLAW_PROFILE이 설정된 경우~/.openclaw/workspace-<profile>). - 상태 기본값은
~/.openclaw/agents/main/agent입니다.
에이전트 헬퍼
에이전트 마법사를 사용하여 새 격리 에이전트를 추가하세요.bindings를 추가하세요(또는 마법사가 처리하게 하세요).
다음으로 확인하세요.
빠른 시작
각 에이전트 워크스페이스 만들기
마법사를 사용하거나 워크스페이스를 수동으로 만드세요.각 에이전트는
SOUL.md, AGENTS.md, 선택적 USER.md가 포함된 자체 워크스페이스와 전용 agentDir, 그리고 ~/.openclaw/agents/<agentId> 아래의 세션 저장소를 갖습니다.에이전트, 계정, 바인딩 추가하기
agents.list 아래에 에이전트를, channels.<channel>.accounts 아래에 채널 계정을 추가하고, bindings로 연결하세요(예시는 아래 참고).여러 에이전트 = 여러 사람, 여러 성격
여러 에이전트를 사용하면 각agentId가 완전히 격리된 페르소나가 됩니다.
- 서로 다른 전화번호/계정(채널별
accountId). - 서로 다른 성격(
AGENTS.md,SOUL.md같은 에이전트별 워크스페이스 파일). - 분리된 인증 + 세션(명시적으로 활성화하지 않는 한 상호 간섭 없음).
크로스 에이전트 QMD 메모리 검색
한 에이전트가 다른 에이전트의 QMD 세션 트랜스크립트를 검색해야 하는 경우agents.list[].memorySearch.qmd.extraCollections 아래에 추가 컬렉션을 넣으세요. 모든 에이전트가 동일한 공유 트랜스크립트 컬렉션을 상속해야 할 때만 agents.defaults.memorySearch.qmd.extraCollections를 사용하세요.
하나의 WhatsApp 번호, 여러 사람(DM 분할)
하나의 WhatsApp 계정을 유지하면서 서로 다른 WhatsApp DM을 서로 다른 에이전트로 라우팅할 수 있습니다.peer.kind: "direct"로 발신자 E.164(예: +15551234567)를 매칭하세요. 답장은 여전히 같은 WhatsApp 번호에서 전송됩니다(에이전트별 발신자 ID 없음).
다이렉트 채팅은 에이전트의 메인 세션 키로 합쳐지므로, 진정한 격리에는 사람별로 하나의 에이전트가 필요합니다.
- DM 접근 제어는 에이전트별이 아니라 WhatsApp 계정별 전역입니다(페어링/허용 목록).
- 공유 그룹의 경우 그룹을 하나의 에이전트에 바인딩하거나 브로드캐스트 그룹을 사용하세요.
라우팅 규칙(메시지가 에이전트를 선택하는 방식)
바인딩은 결정적이며 가장 구체적인 항목이 우선합니다.동률 처리와 AND 의미론
동률 처리와 AND 의미론
- 같은 단계에서 여러 바인딩이 매칭되면 구성 순서상 첫 번째 항목이 우선합니다.
- 바인딩이 여러 매칭 필드(예:
peer+guildId)를 설정하면, 지정된 모든 필드가 필요합니다(AND의미론).
계정 범위 세부 정보
계정 범위 세부 정보
accountId를 생략한 바인딩은 기본 계정에만 매칭됩니다.- 모든 계정에 걸친 채널 전체 대체 경로에는
accountId: "*"를 사용하세요. - 나중에 같은 에이전트에 대해 명시적 계정 id로 같은 바인딩을 추가하면 OpenClaw는 기존 채널 전용 바인딩을 중복 생성하는 대신 계정 범위로 업그레이드합니다.
여러 계정/전화번호
여러 계정(예: WhatsApp)을 지원하는 채널은accountId를 사용하여 각 로그인을 식별합니다. 각 accountId는 서로 다른 에이전트로 라우팅할 수 있으므로, 하나의 서버가 세션을 섞지 않고 여러 전화번호를 호스팅할 수 있습니다.
accountId가 생략되었을 때 채널 전체 기본 계정을 원한다면 channels.<channel>.defaultAccount를 설정하세요(선택 사항). 설정하지 않으면 OpenClaw는 default가 있을 경우 이를 사용하고, 없으면 구성된 첫 번째 계정 id(정렬됨)로 대체합니다.
이 패턴을 지원하는 일반적인 채널은 다음과 같습니다.
whatsapp,telegram,discord,slack,signal,imessageirc,line,googlechat,mattermost,matrix,nextcloud-talkzalo,zalouser,nostr,feishu
개념
agentId: 하나의 “두뇌”(워크스페이스, 에이전트별 인증, 에이전트별 세션 저장소).accountId: 하나의 채널 계정 인스턴스(예: WhatsApp 계정"personal"vs"biz").binding:(channel, accountId, peer)및 선택적 guild/team id를 기준으로 인바운드 메시지를agentId로 라우팅합니다.- 다이렉트 채팅은
agent:<agentId>:<mainKey>로 합쳐집니다(에이전트별 “main”;session.mainKey).
플랫폼 예시
에이전트별 Discord 봇
에이전트별 Discord 봇
각 Discord 봇 계정은 고유한
accountId에 매핑됩니다. 각 계정을 에이전트에 바인딩하고 봇별 허용 목록을 유지하세요.- 각 bot을 길드에 초대하고 Message Content Intent를 활성화합니다.
- token은
channels.discord.accounts.<id>.token에 있습니다. 기본 계정은DISCORD_BOT_TOKEN을 사용할 수 있습니다.
Telegram bots per agent
Telegram bots per agent
- BotFather로 agent마다 bot을 하나씩 만들고 각 token을 복사합니다.
- token은
channels.telegram.accounts.<id>.botToken에 있습니다. 기본 계정은TELEGRAM_BOT_TOKEN을 사용할 수 있습니다.
WhatsApp numbers per agent
WhatsApp numbers per agent
Gateway를 시작하기 전에 각 계정을 연결합니다.
~/.openclaw/openclaw.json (JSON5):일반적인 패턴
- WhatsApp daily + Telegram deep work
- Same channel, one peer to Opus
- Family agent bound to a WhatsApp group
channel별로 분리합니다. WhatsApp은 빠른 일상용 agent로 라우팅하고 Telegram은 Opus agent로 라우팅합니다.참고:
- 한 channel에 여러 계정이 있다면 binding에
accountId를 추가합니다. 예:{ channel: "whatsapp", accountId: "personal" }. - 나머지는 chat에 유지하면서 단일 DM/group만 Opus로 라우팅하려면 해당 peer에 대한
match.peerbinding을 추가합니다. peer 일치는 항상 channel 전체 규칙보다 우선합니다.
agent별 sandbox 및 tool 구성
각 agent는 자체 sandbox와 tool 제한을 가질 수 있습니다.setupCommand는 sandbox.docker 아래에 있으며 container 생성 시 한 번 실행됩니다. resolved scope가 "shared"이면 agent별 sandbox.docker.* override는 무시됩니다.- 보안 격리: 신뢰할 수 없는 agent의 tool을 제한합니다.
- 리소스 제어: 특정 agent는 sandbox에 두고 다른 agent는 host에 유지합니다.
- 유연한 정책: agent별로 서로 다른 권한을 적용합니다.
tools.elevated는 global이며 sender 기반입니다. agent별로 구성할 수 없습니다. agent별 경계가 필요하다면 agents.list[].tools를 사용해 exec를 거부하세요. group targeting에는 agents.list[].groupChat.mentionPatterns를 사용해 @mention이 의도한 agent로 깔끔하게 매핑되도록 합니다.관련 항목
- ACP agents — 외부 coding harness 실행
- Channel routing — message가 agent로 라우팅되는 방식
- Presence — agent presence와 availability
- Session — session 격리 및 라우팅
- Sub-agents — 백그라운드 agent run 생성