Hermes Agent 技能编写
编写仓库内 SKILL.md:frontmatter、验证器、结构。
技能元数据
| 来源 | 内置(默认安装) |
| 路径 | skills/software-development/hermes-agent-skill-authoring |
| 版本 | 1.0.0 |
| 作者 | Hermes Agent |
| 许可证 | MIT |
| 平台 | linux, macos, windows |
| 标签 | skills, authoring, hermes-agent, conventions, skill-md |
| 相关技能 | writing-plans, requesting-code-review |
参考:完整 SKILL.md
以下是该技能被触发时 Hermes 加载的完整技能定义。当技能激活时,Agent 会将其视为指令。
编写 Hermes-Agent 技能(仓库内)
概述
SKILL.md 可以存放在两个位置:
- 用户本地:
~/.hermes/skills/<maybe-category>/<name>/SKILL.md— 个人使用,不共享。通过skill_manage(action='create')创建。 - 仓库内(本技能针对此场景):
/home/bb/hermes-agent/skills/<category>/<name>/SKILL.md— 随包提交并发布。使用write_file+git add。skill_manage(action='create')不会操作此目录树。
何时使用
- 用户要求你“在此分支/仓库/提交中”添加一个技能
- 你正在提交一个应随 hermes-agent 一起发布的可复用工作流
- 你正在编辑
/home/bb/hermes-agent/skills/下的已有技能(小修改用patch,重写用write_file;skill_manage仍可用于仓库内技能的补丁,但不适用于create)
必需的 Frontmatter
验证依据:tools/skill_manager_tool.py::_validate_frontmatter。硬性要求:
- 以
---作为文件开头(前面不能有空行)。 - 以
\n---\n结束,之后才是正文。 - 可解析为 YAML 映射。
- 必须包含
name字段。 - 必须包含
description字段,且长度 ≤ 1024 字符(MAX_DESCRIPTION_LENGTH)。 - 结束
---之后必须有非空正文。
skills/software-development/ 下所有技能都遵循的通用格式:
---
name: my-skill-name # 小写,连字符,≤64 字符(MAX_NAME_LENGTH)
description: 当 <触发条件> 时使用。<一行行为描述>。
version: 1.0.0
author: Hermes Agent
license: MIT
metadata:
hermes:
tags: [简短, 描述性, 标签]
related_skills: [other-skill, another-skill]
---
version / author / license / metadata 并非验证器强制要求,但所有同类技能都包含它们——省略的话你的技能会显得格格不入。
大小限制
- 描述:≤ 1024 字符(强制)。
- 完整 SKILL.md:≤ 100,000 字符(强制,
MAX_SKILL_CONTENT_CHARS,约 36k tokens)。 software-development/下的同类技能大小在 8-14k 字符。尽量保持在这个范围。如果超过 20k,请拆分为references/*.md并在 SKILL.md 中引用它们。
对等结构
仓库内的每个技能大致遵循以下结构:
# <标题>
## 概述
一到两段:说明是什么以及为什么。
## 何时使用
- 触发条件列表
- "不要用于:"反触发条件
## <技能特有的主题章节>
- 常见快速参考表
- 包含具体命令的代码块
- Hermes 专属配方(通过 scripts/run_tests.sh 运行测试、ui-tui 路径等)
## 常见陷阱
错误及其修复方法的编号列表。
## 验证清单
- [ ] 操作后验证的复选框列表
## 一次性配方(可选)
命名场景 → 具体的命令序列。
并非每个章节都是强制性的,但 概述 + 何时使用 + 可操作正文 + 陷阱是让技能感觉像对等技能的最低要求。
目录放置
skills/<类别>/<技能名称>/SKILL.md
仓库中当前的类别(通过 ls skills/ 确认):autonomous-ai-agents、creative、data-science、devops、dogfood、email、gaming、github、leisure、mcp、media、mlops/*、note-taking、productivity、red-teaming、research、smart-home、social-media、software-development。
选择最接近的现有类别。不要随意创建新的顶级类别。
工作流程
- 调研目标类别中的对等技能:
阅读 2-3 个对等 SKILL.md 文件,以匹配语气和结构。
ls skills/<类别>/ - 如果不确定,检查验证器约束,在
tools/skill_manager_tool.py中。 - 起草,使用
write_file写入skills/<类别>/<名称>/SKILL.md。 - 本地验证:
import yaml, re, pathlib
content = pathlib.Path("skills/<类别>/<名称>/SKILL.md").read_text()
assert content.startswith("---")
m = re.search(r'\n---\s*\n', content[3:])
fm = yaml.safe_load(content[3:m.start()+3])
assert "name" in fm and "description" in fm
assert len(fm["description"]) <= 1024
assert len(content) <= 100_000 - Git add + commit 在活动分支上。
- 注意: 当前会话的技能加载器是缓存的——
skill_view/skills_list在新会话之前不会看到新技能。这是预期行为,不是 bug。
交叉引用其他技能
metadata.hermes.related_skills 在加载时会合并两个树(仓库内的 skills/ 和 ~/.hermes/skills/)。你可以从仓库内技能引用用户本地技能,但对于克隆新仓库的其他用户来说,该引用将无法解析。建议只从仓库内技能引用仓库内技能。如果一个经常被引用的技能只存在于 ~/.hermes/skills/ 中,考虑将其提升到仓库中。
编辑现有仓库内技能
- 小修复(拼写错误、添加陷阱、收紧触发条件):
skill_manage(action='patch', name=..., old_string=..., new_string=...)对仓库内技能有效。 - 重大重写: 使用
write_file写入整个 SKILL.md。skill_manage(action='edit')也有效,但需要提供完整的新内容。 - 添加支持文件: 使用
write_file写入skills/<类别>/<名称>/references/<文件>.md、templates/<文件>或scripts/<文件>。skill_manage(action='write_file')也有效,并且会强制执行 references/templates/scripts/assets 子目录白名单。 - 始终提交 编辑——仓库内技能是源代码,而不是运行时状态。
常见陷阱
-
对仓库内的技能使用
skill_manage(action='create')。 该命令会将技能写入~/.hermes/skills/,而不是仓库目录中。如需在仓库内创建技能,应使用write_file。 -
---前有前置空白字符。 校验器会检查content.startswith("---");任何前导空行或 BOM 都会导致校验失败。 -
描述过于笼统。 Peer 描述应以 "Use when ..." 开头,并描述触发类别,而非某一具体任务。"Use when debugging X" 优于 "Debug X"。
-
忘记作者/许可证/metadata 块。 虽然校验器不强制要求,但每个 peer 都有此块;缺失会使技能显得不完整。
-
编写与已有 peer 重复的技能。 在创建前,先执行
ls skills/<category>/并打开 2-3 个 peer。优先扩展现有技能,而不是创建一个功能相近的新技能。 -
期望当前会话能看到新技能。 这是不可能的。技能加载器在会话启动时初始化。请在新会话中验证,或使用
skill_view并指定精确路径来验证。 -
链接到仓库中不存在的技能。
related_skills: [some-user-local-skill]对你有效,但对其他克隆者无效。建议只链接仓库内的技能。
验证清单
- 文件位于
skills/<category>/<name>/SKILL.md(不在~/.hermes/skills/) - Frontmatter 从字节 0 开始,以
---开头,以\n---\n结束 - 包含
name、description、version、author、license、metadata.hermes.{tags, related_skills} - name 不超过 64 个字符,全小写并使用连字符
- description 不超过 1024 个字符,并以 "Use when ..." 开头
- 文件总字符数不超过 100,000(建议控制在 8-15k)
- 结构为:
# Title→## Overview→## When to Use→ 正文 →## Common Pitfalls→## Verification Checklist -
related_skills引用在仓库内可解析(或者明确允许为用户本地技能) - 已在目标分支上执行
git add skills/<category>/<name>/ && git commit