멀티 에이전트 샌드박스 및 도구 구성
멀티 에이전트 설정에서는 각 에이전트가 전역 샌드박스 및 도구 정책을 재정의할 수 있습니다. 이 페이지에서는 에이전트별 구성, 우선순위 규칙, 예시를 다룹니다.- 샌드박스 백엔드 및 모드: 샌드박싱을 참조하세요.
- 차단된 도구 디버깅: 샌드박스 vs 도구 정책 vs Elevated 및
openclaw sandbox explain을 참조하세요. - Elevated exec: Elevated 모드를 참조하세요.
~/.openclaw/agents/<agentId>/agent/auth-profiles.json에 있는 자체 agentDir 인증 저장소를 읽습니다.
자격 증명은 에이전트 간에 공유되지 않습니다. 에이전트 간에 agentDir를 재사용하지 마세요.
자격 증명을 공유하려면 auth-profiles.json을 다른 에이전트의 agentDir로 복사하세요.
구성 예시
예시 1: 개인용 + 제한된 가족용 에이전트
main에이전트: 호스트에서 실행, 전체 도구 액세스family에이전트: Docker에서 실행(에이전트당 하나의 컨테이너),read도구만 사용 가능
예시 2: 공유 샌드박스를 사용하는 업무용 에이전트
예시 2b: 전역 coding 프로필 + 메시징 전용 에이전트
- 기본 에이전트는 coding 도구를 받습니다
support에이전트는 메시징 전용입니다(+ Slack 도구)
예시 3: 에이전트별로 다른 샌드박스 모드
구성 우선순위
전역(agents.defaults.*) 및 에이전트별(agents.list[].*) 구성이 모두 존재할 때:
샌드박스 구성
에이전트별 설정이 전역 설정보다 우선합니다:agents.list[].sandbox.{docker,browser,prune}.*는 해당 에이전트에 대해agents.defaults.sandbox.{docker,browser,prune}.*를 재정의합니다(샌드박스 범위가"shared"로 해석되면 무시됨).
도구 제한
필터링 순서는 다음과 같습니다:- 도구 프로필 (
tools.profile또는agents.list[].tools.profile) - 공급자 도구 프로필 (
tools.byProvider[provider].profile또는agents.list[].tools.byProvider[provider].profile) - 전역 도구 정책 (
tools.allow/tools.deny) - 공급자 도구 정책 (
tools.byProvider[provider].allow/deny) - 에이전트별 도구 정책 (
agents.list[].tools.allow/deny) - 에이전트 공급자 정책 (
agents.list[].tools.byProvider[provider].allow/deny) - 샌드박스 도구 정책 (
tools.sandbox.tools또는agents.list[].tools.sandbox.tools) - 하위 에이전트 도구 정책 (
tools.subagents.tools, 해당하는 경우)
agents.list[].tools.sandbox.tools가 설정되면 해당 에이전트에 대해 tools.sandbox.tools를 대체합니다.
agents.list[].tools.profile이 설정되면 해당 에이전트에 대해 tools.profile을 재정의합니다.
공급자 도구 키는 provider(예: google-antigravity) 또는 provider/model(예: openai/gpt-5.4)을 사용할 수 있습니다.
도구 정책은 여러 도구로 확장되는 group:* 축약형을 지원합니다. 전체 목록은 도구 그룹를 참조하세요.
에이전트별 Elevated 재정의(agents.list[].tools.elevated)는 특정 에이전트에 대한 elevated exec를 추가로 제한할 수 있습니다. 자세한 내용은 Elevated 모드를 참조하세요.
단일 에이전트에서 마이그레이션
이전(단일 에이전트):agent.* 구성은 openclaw doctor로 마이그레이션됩니다. 앞으로는 agents.defaults + agents.list를 사용하는 것이 좋습니다.
도구 제한 예시
읽기 전용 에이전트
안전한 실행 에이전트(파일 수정 없음)
통신 전용 에이전트
sessions_history는 여전히 원시 전사 덤프가 아니라 제한되고 정제된 회상 보기를 반환합니다. 어시스턴트 회상에서는 thinking 태그, <relevant-memories> 스캐폴딩, 일반 텍스트 도구 호출 XML 페이로드( <tool_call>...</tool_call>,
<function_call>...</function_call>, <tool_calls>...</tool_calls>,
<function_calls>...</function_calls>, 잘린 도구 호출 블록 포함),
축소된 도구 호출 스캐폴딩, 유출된 ASCII/전각 모델 제어 토큰,
잘못된 MiniMax 도구 호출 XML을 제거한 후 마스킹/잘라내기를 적용합니다.
흔한 함정: "non-main"
agents.defaults.sandbox.mode: "non-main"은 에이전트 ID가 아니라 session.mainKey(기본값 "main")를 기준으로 합니다.
그룹/채널 세션은 항상 자체 키를 가지므로 non-main으로 처리되어 샌드박스됩니다.
에이전트를 절대 샌드박스하지 않으려면 agents.list[].sandbox.mode: "off"를 설정하세요.
테스트
멀티 에이전트 샌드박스 및 도구를 구성한 후:-
에이전트 해석 확인:
-
샌드박스 컨테이너 확인:
-
도구 제한 테스트:
- 제한된 도구가 필요한 메시지를 보냅니다
- 에이전트가 거부된 도구를 사용할 수 없는지 확인합니다
-
로그 모니터링:
문제 해결
mode: "all"인데도 에이전트가 샌드박스되지 않음
- 이를 재정의하는 전역
agents.defaults.sandbox.mode가 있는지 확인하세요 - 에이전트별 구성이 우선하므로
agents.list[].sandbox.mode: "all"을 설정하세요
거부 목록이 있는데도 도구를 계속 사용할 수 있음
- 도구 필터링 순서를 확인하세요: 전역 → 에이전트 → 샌드박스 → 하위 에이전트
- 각 단계는 더 제한할 수만 있고, 다시 허용할 수는 없습니다
- 로그로 확인하세요:
[tools] filtering tools for agent:${agentId}
컨테이너가 에이전트별로 격리되지 않음
- 에이전트별 샌드박스 구성에서
scope: "agent"를 설정하세요 - 기본값은
"session"이며 세션당 하나의 컨테이너를 생성합니다
함께 보기
- 샌드박싱 — 전체 샌드박스 참조(모드, 범위, 백엔드, 이미지)
- 샌드박스 vs 도구 정책 vs Elevated — “왜 이것이 차단되나요?” 디버깅
- Elevated 모드
- 멀티 에이전트 라우팅
- 샌드박스 구성
- 세션 관리