Skills 配置
所有与 Skills 相关的配置都位于 ~/.openclaw/openclaw.json 中的 skills 下。
json5
{
skills: {
allowBundled: ["gemini", "peekaboo"],
load: {
extraDirs: ["~/Projects/agent-scripts/skills", "~/Projects/oss/some-skill-pack/skills"],
watch: true,
watchDebounceMs: 250,
},
install: {
preferBrew: true,
nodeManager: "npm", // npm | pnpm | yarn | bun (Gateway runtime still Node; bun not recommended)
},
entries: {
"nano-banana-pro": {
enabled: true,
apiKey: "GEMINI_KEY_HERE",
env: {
GEMINI_API_KEY: "GEMINI_KEY_HERE",
},
},
peekaboo: { enabled: true },
sag: { enabled: false },
},
},
}字段
allowBundled:仅用于捆绑 Skills 的可选允许列表。设置后,只有列表中的捆绑 Skills 才符合条件(不影响托管/工作区 Skills)。load.extraDirs:要扫描的额外 Skills 目录(优先级最低)。load.watch:监视 Skills 文件夹并刷新 Skills 快照(默认值:true)。load.watchDebounceMs:Skills 监视器事件的防抖延迟,以毫秒为单位(默认值:250)。install.preferBrew:在可用时优先使用 brew 安装器(默认值:true)。install.nodeManager:node 安装器偏好设置(npm|pnpm|yarn|bun,默认值:npm)。 这仅影响 Skills 安装;Gateway 网关运行时仍应使用 Node (不建议在 WhatsApp/Telegram 中使用 Bun)。entries.<skillKey>:单个 Skills 的覆盖配置。
单个 Skills 字段:
enabled:设置为false可禁用 Skills,即使它已捆绑/安装。env:为智能体运行注入的环境变量(仅在尚未设置时注入)。apiKey:为声明主环境变量的 Skills 提供的可选便利选项。
注意事项
entries下的键默认映射到 Skills 名称。如果 Skills 定义了metadata.openclaw.skillKey,则改用该键。- 启用监视器时,对 Skills 的更改将在下一个智能体轮次时被检测到。
沙箱隔离 Skills + 环境变量
当会话处于沙箱隔离模式时,Skills 进程在 Docker 内运行。沙箱 不会继承宿主机的 process.env。
请使用以下方式之一:
agents.defaults.sandbox.docker.env(或按智能体设置的agents.list[].sandbox.docker.env)- 将环境变量烘焙到自定义沙箱镜像中
全局 env 和 skills.entries.<skill>.env/apiKey 仅适用于宿主机运行。