Skills 总览
本页对 skill 的定义参考了 Agent Skills 的描述:skill 是一种轻量、自包含的能力包,智能体可以按需发现、加载并执行。
什么是 skill?
在 DB-GPT 中,skill 是一种可复用的能力包,为智能体提供完成某类任务的结构化方式。
相比只依赖自由推理,skill 为特定类型的工作提供了更稳定、更可重复的执行模式。
Skill 的定义
结合 Agent Skills 的定义,可以把 skill 理解为:
- 一种为智能体提供专业知识和工作流的轻量扩展格式
- 一种经验与方法的打包形式,而不只是事实、API 或 prompt
- 一种渐进式暴露的能力单元:先发现,真正需要时再 完整加载
- 一个自包含的指令、脚本、模板和参考资料集合
- 一种让智能体行为更稳定、可重复、具备领域感知的方式
在 DB-GPT 语境里,skill 不只是“模型知道什么”,而是一个打包好的工作流,帮助智能体决定:
- 它要解决什么问题
- 它应该调用哪些工具
- 执行步骤应遵循怎样的顺序
- 需要产出什么结果
- 需要遵守哪些约束
一个 skill 通常包含什么
一个 DB-GPT skill 包通常包括:
- 名称
SKILL.md中的说明与指令- 可选脚本
- 可选模板
- 可选静态资源或示例
从本质上说,skill 是一个包含 SKILL.md 的目录。这个文件定义元数据与执行指令,告诉智能体如何完成某类任务。skill 还可以附带脚本、模板和参考资料。
my-skill/
├── SKILL.md # Required: instructions + metadata
├── scripts/ # Optional: executable code
├── references/ # Optional: documentation loaded as needed
└── assets/ # Optional: templates, output resources, static files
Skill 结构
按照 DB-GPT 当前 skill-creator 的实践,一个 skill 通常组织为一个小型、自包含的能力包:
| 部分 | 必需 | 作用 |
|---|---|---|
SKILL.md | 是 | 定义 skill 的身份信息与执行指令 |
scripts/ | 否 | 存放可执行代码,如 Python 或 shell 辅助脚本 |
references/ | 否 | 存放按需加载进上下文的参考文档 |
assets/ | 否 | 存放模板、字体、图标、样板文件或其他输出资源 |
SKILL.md
SKILL.md 是 skill 的入口文件,通常包含:
name、description等元数据- 智能体应遵循的工作流指令
- 什么时候读取附加参考资料或使用打包资源的说明
scripts/
scripts/ 用于放置可执行辅助程序,例如:
- Python 数据处理脚本
- shell 脚本
- 报告生成辅助代码
- skill 运行中需要的自动化代码
references/
references/ 用于保存不适合一直塞进 SKILL.md 的补充知识,例如:
- API 文档
- 业务逻辑说明
- schema 定义
- 工作流指南
- 领域规范或策略文档
这样既能保持 SKILL.md 精简,又能在需要时为智能体提供更深的上下文。
assets/
assets/ 用于存放更多面向输出而不是推理过程的资源,例如:
- HTML 模板
- 图标与 logo
- 字体
- 前端样板文件
- 报告资源