Песочница
Бэкенды и режимы — полный справочник по песочнице.
Песочница, политика инструментов и повышенный режим
Отладка вопроса «почему это заблокировано?»
Повышенный режим
Повышенный exec для доверенных отправителей.
Примеры конфигурации
Пример 1: личный агент + ограниченный семейный агент
Пример 1: личный агент + ограниченный семейный агент
- агент
main: работает на хосте, полный доступ к инструментам. - агент
family: работает в Docker (один контейнер на агента), доступны толькоreadи отправка сообщений в текущей беседе.
Пример 2: рабочий агент с общей песочницей
Пример 2: рабочий агент с общей песочницей
Пример 2b: глобальный профиль программирования + агент только для сообщений
Пример 2b: глобальный профиль программирования + агент только для сообщений
- агенты по умолчанию получают инструменты для программирования.
- агент
supportработает только с сообщениями (+ инструмент Slack).
Пример 3: разные режимы песочницы для разных агентов
Пример 3: разные режимы песочницы для разных агентов
Приоритет конфигурации
Когда существуют и глобальные (agents.defaults.*), и агентские (agents.list[].*) конфигурации:
Конфигурация песочницы
Настройки конкретного агента переопределяют глобальные:agents.list[].sandbox.{docker,browser,prune}.* переопределяет agents.defaults.sandbox.{docker,browser,prune}.* для этого агента (игнорируется, когда область песочницы разрешается в "shared").Ограничения инструментов
Порядок фильтрации:Профиль инструментов провайдера
tools.byProvider[provider].profile или agents.list[].tools.byProvider[provider].profile.Правила приоритета
Правила приоритета
- Каждый уровень может дополнительно ограничивать инструменты, но не может снова разрешить инструменты, запрещенные на предыдущих уровнях.
- Если задано
agents.list[].tools.sandbox.tools, оно заменяетtools.sandbox.toolsдля этого агента. - Если задано
agents.list[].tools.profile, оно переопределяетtools.profileдля этого агента. - Ключи инструментов провайдера принимают либо
provider(например,google-antigravity), либоprovider/model(например,openai/gpt-5.4).
Поведение пустого списка разрешений
Поведение пустого списка разрешений
Если любой явный список разрешений в этой цепочке оставляет запуск без доступных для вызова инструментов, OpenClaw останавливается до отправки промпта модели. Это сделано намеренно: агент, настроенный с отсутствующим инструментом, например
agents.list[].tools.allow: ["query_db"], должен явно завершаться ошибкой, пока не будет включен Plugin, регистрирующий query_db, а не продолжать работу как агент только с текстом.group:*, которые раскрываются в несколько инструментов. Полный список см. в разделе Группы инструментов.
Переопределения повышенного режима для отдельных агентов (agents.list[].tools.elevated) могут дополнительно ограничивать повышенный exec для конкретных агентов. Подробнее см. в разделе Повышенный режим.
Миграция с одного агента
- До (один агент)
- После (мультиагентный режим)
Устаревшие конфигурации
agent.* мигрируются через openclaw doctor; в дальнейшем предпочитайте agents.defaults + agents.list.Примеры ограничений инструментов
- Агент только для чтения
- Выполнение shell с отключенными файловыми инструментами
- Только коммуникация
Распространенная ошибка: “non-main”
Тестирование
После настройки мультиагентной песочницы и инструментов:Проверьте ограничения инструментов
- Отправьте сообщение, требующее ограниченных инструментов.
- Убедитесь, что агент не может использовать запрещенные инструменты.
Устранение неполадок
Агент не запускается в песочнице, несмотря на `mode: 'all'`
Агент не запускается в песочнице, несмотря на `mode: 'all'`
- Проверьте, есть ли глобальный
agents.defaults.sandbox.mode, который переопределяет это значение. - Конфигурация конкретного агента имеет приоритет, поэтому задайте
agents.list[].sandbox.mode: "all".
Инструменты все еще доступны, несмотря на список запретов
Инструменты все еще доступны, несмотря на список запретов
- Проверьте порядок фильтрации инструментов: глобальный → агент → песочница → субагент.
- Каждый уровень может только дополнительно ограничивать, а не возвращать доступ.
- Проверьте по журналам:
[tools] filtering tools for agent:${agentId}.
Контейнер не изолирован для каждого агента
Контейнер не изолирован для каждого агента
- Задайте
scope: "agent"в конфигурации песочницы конкретного агента. - Значение по умолчанию —
"session", при котором создается один контейнер на сеанс.
Связанные материалы
- Повышенный режим
- Маршрутизация между несколькими агентами
- Конфигурация песочницы
- Песочница, политика инструментов и повышенный режим — отладка «почему это заблокировано?»
- Песочница — полный справочник по песочнице (режимы, области, бэкенды, образы)
- Управление сеансами