Конфигурация песочницы и инструментов для нескольких агентов
Обзор
Каждый агент в многоагентной конфигурации теперь может иметь собственные:- Настройки песочницы (
agents.list[].sandboxпереопределяетagents.defaults.sandbox) - Ограничения инструментов (
tools.allow/tools.deny, плюсagents.list[].tools)
- Персональный ассистент с полным доступом
- Семейные/рабочие агенты с ограниченными инструментами
- Публичные агенты, работающие в песочницах
setupCommand относится к разделу sandbox.docker (глобально или для конкретного агента) и выполняется один раз
при создании контейнера.
Аутентификация — для каждого агента: каждый агент читает из собственного хранилища аутентификации agentDir по адресу:
agentDir между агентами.
Если требуется разделить учетные данные, скопируйте auth-profiles.json в agentDir другого агента.
О том, как работает sandboxing во время выполнения, см. Sandboxing.
Для отладки «почему это заблокировано?» см. Sandbox vs Tool Policy vs Elevated и openclaw sandbox explain.
Примеры конфигурации
Пример 1: Персональный агент + ограниченный семейный агент
- агент
main: работает на хосте, полный доступ к инструментам - агент
family: работает в Docker (один контейнер на агента), только инструментread
Пример 2: Рабочий агент с общей песочницей
Пример 2b: Глобальный профиль для кодинга + агент только для сообщений
- агенты по умолчанию получают инструменты для кодинга
- агент
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.2).
Группы инструментов (сокращения)
Политики инструментов (глобальные, агентные, песочницы) поддерживают записиgroup:*, которые разворачиваются в несколько конкретных инструментов:
group:runtime:exec,bash,processgroup:fs:read,write,edit,apply_patchgroup:sessions:sessions_list,sessions_history,sessions_send,sessions_spawn,session_statusgroup:memory:memory_search,memory_getgroup:ui:browser,canvasgroup:automation:cron,gatewaygroup:messaging:messagegroup:nodes:nodesgroup:openclaw: все встроенные инструменты OpenClaw (исключая плагины провайдеров)
Режим Elevated
tools.elevated — глобальная база (список разрешённых на основе отправителя). agents.list[].tools.elevated может дополнительно ограничивать elevated для конкретных агентов (должны разрешать оба).
Шаблоны смягчения рисков:
- Запретить
execдля недоверенных агентов (agents.list[].tools.deny: ["exec"]) - Избегать добавления в список разрешённых отправителей, которые маршрутизируют к ограниченным агентам
- Отключить elevated глобально (
tools.elevated.enabled: false), если требуется только выполнение в песочнице - Отключить elevated для конкретного агента (
agents.list[].tools.elevated.enabled: false) для чувствительных профилей
Миграция с одного агента
До (один агент):agent.* мигрируются с помощью openclaw doctor; в дальнейшем предпочтительно использовать agents.defaults + agents.list.
Примеры ограничений инструментов
Агент только для чтения
Агент безопасного выполнения (без модификации файлов)
Агент только для коммуникаций
Распространенный Питпад: “Неосновный”
agents.defaults.sandbox.mode: "non-main" основан на 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", при котором создаётся один контейнер на сеанс