沙箱 CLI
管理用于隔离代理执行的沙箱运行时。概述
OpenClaw 可以在隔离的沙箱运行时中运行代理以确保安全。sandbox 命令可帮助您在更新或配置更改后检查并重新创建这些运行时。
如今这通常意味着:
- Docker 沙箱容器
- 当
agents.defaults.sandbox.backend = "ssh"时的 SSH 沙箱运行时 - 当
agents.defaults.sandbox.backend = "openshell"时的 OpenShell 沙箱运行时
ssh 和 OpenShell remote,重新创建比使用 Docker 更为重要:
- 在初始种子之后,远程工作区是规范的
openclaw sandbox recreate会删除所选作用域的规范远程工作区- 下次使用时会从当前的本地工作区再次进行种子化
命令
openclaw sandbox explain
检查有效的沙箱模式/作用域/工作区访问权限、沙箱工具策略以及提升的门控(附带修复配置键路径)。
openclaw sandbox list
列出所有沙箱运行时及其状态和配置。
- 运行时名称和状态
- 后端(
docker、openshell等) - 配置标签及其是否与当前配置匹配
- 存在时间(自创建以来的时间)
- 空闲时间(自上次使用以来的时间)
- 关联的会话/代理
openclaw sandbox recreate
移除沙箱运行时以强制使用更新后的配置进行重新创建。
--all:重新创建所有沙箱容器--session <key>:重新创建特定会话的容器--agent <id>:重新创建特定代理的容器--browser:仅重新创建浏览器容器--force:跳过确认提示
用例
更新 Docker 镜像后
更改沙箱配置后
更改 SSH 目标或 SSH 身份验证材料后
ssh 后端,recreate 会删除 SSH 目标上每个作用域(per-scope)的远程工作区根目录。下次运行时会从本地工作区重新对其进行种子处理。
更改 OpenShell 源、策略或模式后
remote 模式,recreate 会删除该作用域的规范远程工作区。下次运行时会从本地工作区重新对其进行种子处理。
更改 setupCommand 后
仅针对特定代理
为什么需要这样做?
问题: 当你更新沙箱配置时:- 现有运行时会继续使用旧设置运行
- 运行时仅在闲置 24 小时后被清理
- 定期使用的代理会无限期地保持旧运行时的活跃状态
openclaw sandbox recreate 强制删除旧的运行时。下次需要时,它们将使用当前设置自动重新创建。
提示:优先使用 openclaw sandbox recreate 而非手动进行特定于后端的清理。
它使用 Gateway(网关) 的运行时注册表,并避免在作用域/会话密钥更改时出现不匹配。
配置
沙箱设置位于agents.defaults.sandbox 下的 ~/.openclaw/openclaw.json 中(每个代理的覆盖设置位于 agents.list[].sandbox 中):
另请参阅
本页面源自 openclaw/openclaw,由 BeaversLab 翻译,遵循 MIT 协议 发布。