79 lines
2.8 KiB
Markdown
79 lines
2.8 KiB
Markdown
---
|
||
read_when:
|
||
- 添加或修改 Skills配置时
|
||
- 调整内置允许列表或安装行为时
|
||
summary: Skills配置结构与示例
|
||
title: Skills配置
|
||
x-i18n:
|
||
generated_at: "2026-02-01T21:42:49Z"
|
||
model: claude-opus-4-5
|
||
provider: pi
|
||
source_hash: e265c93da7856887c11abd92b379349181549e1a02164184d61a8d1f6b2feed5
|
||
source_path: tools/skills-config.md
|
||
workflow: 15
|
||
---
|
||
|
||
# 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网关运行时仍为 Node;不推荐 bun)
|
||
},
|
||
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` 仅适用于**主机**运行。
|