跳转到主要内容
沙箱由 LangBot 主进程配置,Box Runtime 负责实际执行。常规部署只需要选择后端、设置工作目录和安全预设。
本页所有 box.* 配置都写在 data/config.yaml 中。配置文件的位置和加载机制详见系统环境设置

推荐配置

box:
  enabled: true
  backend: 'local'        # 自动从 Docker / Nsjail 里选可用的
  local:
    profile: 'default'
    host_root: './data/box'
    skills_root: 'skills'
  • enabled:沙箱总开关。设为 false 时,沙箱内置工具、Skill 添加/编辑、stdio MCP 托管等依赖 Box 的能力都不可用。
  • backend:见下文「后端选择」。
  • local.profile:安全预设,控制网络、挂载和资源限制。
  • local.host_root:主机上的沙箱工作目录,会映射为沙箱内的 /workspace
  • local.skills_root:Skill 包目录;相对路径解析到 host_root 下,默认 host_root/skills
Skills 只从 Box Runtime 管理的 skill store 加载。Box Runtime 或后端不可用时 Skill 列表为空,新增 / 编辑 / register_skill 都不可用;不会回退扫描 data/skills/

后端选择

沙箱可以跑在本机容器云端box.backend 选择走哪一种:
backend跑在哪行为
local(默认)本机容器自动从 Docker / Nsjail 里选可用的(Docker 优先)
docker本机容器强制使用 Docker,需要 Docker daemon
nsjail本机容器强制使用 Nsjail(仅 Linux),不支持自定义镜像
e2b云端使用 E2B 云沙箱,需要 API Key
local 是「自动选择」的简写,不是和 docker/nsjail 平级的第四种后端。本机容器后端(local/docker/nsjail共用 box.local.* 配置段;云端后端用 box.e2b.* 配置段。
backend 是强制值。设为 docker 时如果 Docker 不可用,不会自动回退到 Nsjail 或 E2B——只有 local 会自动 fan-out。也可以用环境变量 BOX__BACKEND 覆盖配置(优先级高于 config.yaml)。

安全预设

box.local.profile 控制本机后端的网络、挂载、资源限制:
Profile网络挂载资源建议场景
default关闭读写默认限制默认选择
offline_readonly关闭只读更严格读取不可信文件
network_basic开启基础网络读写默认限制需要访问 API 或下载依赖
network_extended开启完整网络读写更宽松开发、调试、复杂任务
优先使用最小权限:不需要网络就用 defaultoffline_readonly;只把必要目录加入 allowed_mount_roots

本机后端配置(box.local.*)

本机后端(local / docker / nsjail)共用以下配置:
配置项默认值说明
local.profiledefault见上文「安全预设」
local.imageDocker 后端的自定义镜像;空 = 用 profile 默认
local.host_root./data/box主机工作目录基础路径,映射为沙箱内 /workspace
local.default_workspace默认工作空间名;空 = <host_root>/default
local.skills_rootskillsSkill 包目录;相对路径解析到 host_root
local.allowed_mount_roots[host_root]Agent 可请求挂载的主机目录白名单
local.workspace_quota_mbnull工作区磁盘配额(MB),null = 用 profile 默认

云端后端配置(box.e2b.*)

设为 backend: 'e2b' 后配置:
配置项默认值说明
e2b.api_keyE2B API Key,也可用 E2B_API_KEY 环境变量
e2b.api_url自建 E2B 服务地址,也可用 E2B_API_URL
e2b.template默认 E2B 模板 ID
E2B 不需要本机 Docker 或 Nsjail,每次执行都走远程沙箱。

Docker Compose 部署

Docker Compose 部署时,沙箱配置写在 langbot 服务上。LangBot 启动后会通过 INIT RPC 把配置下发给 langbot_box
services:
  langbot_box:
    image: rockchin/langbot:latest
    container_name: langbot_box
    profiles: ["box", "all"]
    volumes:
      - ${LANGBOT_BOX_ROOT:-${PWD}/data/box}:${LANGBOT_BOX_ROOT:-${PWD}/data/box}
      - /var/run/docker.sock:/var/run/docker.sock
    command: ["uv", "run", "--no-sync", "-m", "langbot_plugin.cli.__init__", "box"]

  langbot:
    image: rockchin/langbot:latest
    volumes:
      - ./data:/app/data
    environment:
      - BOX__LOCAL__HOST_ROOT=${LANGBOT_BOX_ROOT:-${PWD}/data/box}
      - BOX__LOCAL__SKILLS_ROOT=skills
      - BOX__LOCAL__ALLOWED_MOUNT_ROOTS=${LANGBOT_BOX_ROOT:-${PWD}/data/box}
langbot_box 需要访问 Docker daemon。只在受信任环境中挂载 docker.sock;并保持 Box 根目录在主机和 langbot_box 容器内路径一致。
如需 LangBot 连接外部 Box Runtime(例如远程主机),用 box.runtime.endpoint 指定 URL:
box:
  runtime:
    endpoint: 'ws://192.168.1.10:5410'

环境变量

环境变量写入配置
BOX__ENABLEDbox.enabled
BOX__BACKENDbox.backend
BOX__LOCAL__PROFILEbox.local.profile
BOX__LOCAL__IMAGEbox.local.image
BOX__LOCAL__HOST_ROOTbox.local.host_root
BOX__LOCAL__DEFAULT_WORKSPACEbox.local.default_workspace
BOX__LOCAL__SKILLS_ROOTbox.local.skills_root
BOX__LOCAL__ALLOWED_MOUNT_ROOTSbox.local.allowed_mount_roots,逗号分隔
BOX__LOCAL__WORKSPACE_QUOTA_MBbox.local.workspace_quota_mb
BOX__E2B__API_KEYbox.e2b.api_key
BOX__E2B__API_URLbox.e2b.api_url
BOX__E2B__TEMPLATEbox.e2b.template
不要在 langbot_box 服务上设置 BOX__*LANGBOT_BOX_* 变量;这些变量不会被 Box Runtime 直接读取——它的配置由 LangBot 通过 INIT RPC 下发。