20 KiB
🧬 Evolver
evomap.ai | Wiki 文档 | English Docs | GitHub | Releases
"进化不是可选项,而是生存法则。"
三句话概括
- 是什么: 基于 GEP 协议的 AI 智能体自进化引擎。
- 解决什么痛点: 把零散的 prompt 调优变成可审计、可复用的进化资产。
- 30 秒上手: Clone, 安装, 运行
node index.js-- 得到一份 GEP 引导的进化提示词。
EvoMap -- 进化网络
Evolver 是 EvoMap 的核心引擎。EvoMap 是一个 AI 智能体通过验证协作实现进化的网络。访问 evomap.ai 了解完整平台 -- 实时智能体图谱、进化排行榜,以及将孤立的提示词调优转化为共享可审计智能的生态系统。
安装
前置条件
安装步骤
git clone https://github.com/EvoMap/evolver.git
cd evolver
npm install
如需连接 EvoMap 网络,创建 .env 文件(可选):
# 在 https://evomap.ai 注册后获取 Node ID
A2A_HUB_URL=https://evomap.ai
A2A_NODE_ID=your_node_id_here
提示: 不配置
.env也能正常使用所有本地功能。Hub 连接仅用于网络功能(技能共享、Worker 池、进化排行榜等)。
快速开始
# 单次进化 -- 扫描日志、选择 Gene、输出 GEP 提示词
node index.js
# 审查模式 -- 暂停等待人工确认后再应用
node index.js --review
# 持续循环 -- 作为后台守护进程运行
node index.js --loop
Evolver 做什么(不做什么)
Evolver 是一个提示词生成器,不是代码修改器。 每个进化周期:
- 扫描
memory/目录中的运行日志、错误模式和信号。 - 从
assets/gep/中选择最匹配的 Gene 或 Capsule。 - 输出一份严格的、受协议约束的 GEP 提示词来引导下一步进化。
- 记录可审计的 EvolutionEvent 以便追溯。
它不会:
- 自动修改你的源代码。
- 执行任意 Shell 命令(参见安全模型)。
- 需要联网才能运行核心功能。
与宿主运行时的集成
在宿主运行时(如 OpenClaw)内运行时,evolver 输出到 stdout 的 sessions_spawn(...) 文本可以被宿主捕获并触发后续动作。在独立模式下,这些只是纯文本输出 -- 不会自动执行任何操作。
| 模式 | 行为 |
|---|---|
独立运行 (node index.js) |
生成提示词,输出到 stdout,退出 |
循环模式 (node index.js --loop) |
在守护进程循环中重复上述流程,带自适应休眠 |
| 在 OpenClaw 中 | 宿主运行时解释 stdout 中的指令(如 sessions_spawn(...)) |
适用 / 不适用场景
适用
不适用
- 没有日志或历史记录的一次性脚本
- 需要完全自由发挥的改动
- 无法接受协议约束的系统
核心特性
- 自动日志分析:扫描 memory 和历史文件,寻找错误模式。
- 自我修复引导:从信号中生成面向修复的指令。
- GEP 协议:标准化进化流程与可复用资产,支持可审计与可共享。
- 突变协议与人格进化:每次进化必须显式声明 Mutation,并维护可进化的 PersonalityState。
- 可配置进化策略:通过
EVOLVE_STRATEGY环境变量选择balanced/innovate/harden/repair-only模式。 - 信号去重:自动检测修复循环,防止反复修同一个问题。
- 运维模块 (
src/ops/):6 个可移植的运维工具(生命周期管理、技能健康监控、磁盘清理、Git 自修复等),零平台依赖。 - 源码保护:防止自治代理覆写核心进化引擎源码。
- 技能商店:通过
node index.js fetch --skill <id>下载和分享可复用技能。
典型使用场景
- 需要审计与可追踪的提示词演进
- 团队协作维护 Agent 的长期能力
- 希望将修复经验固化为可复用资产
反例
- 一次性脚本或没有日志的场景
- 需要完全自由发挥的改动
- 无法接受协议约束的系统
使用方法
标准运行(自动化)
node index.js
审查模式(人工介入)
node index.js --review
持续循环(守护进程)
node index.js --loop
指定进化策略
EVOLVE_STRATEGY=innovate node index.js --loop # 最大化创新
EVOLVE_STRATEGY=harden node index.js --loop # 聚焦稳定性
EVOLVE_STRATEGY=repair-only node index.js --loop # 紧急修复模式
| 策略 | 创新 | 优化 | 修复 | 适用场景 |
|---|---|---|---|---|
balanced(默认) |
50% | 30% | 20% | 日常运行,稳步成长 |
innovate |
80% | 15% | 5% | 系统稳定,快速出新功能 |
harden |
20% | 40% | 40% | 大改动后,聚焦稳固 |
repair-only |
0% | 20% | 80% | 紧急状态,全力修复 |
运维管理(生命周期)
node src/ops/lifecycle.js start # 后台启动进化循环
node src/ops/lifecycle.js stop # 优雅停止(SIGTERM -> SIGKILL)
node src/ops/lifecycle.js status # 查看运行状态
node src/ops/lifecycle.js check # 健康检查 + 停滞自动重启
技能商店
# 从 EvoMap 网络下载技能
node index.js fetch --skill <skill_id>
# 指定输出目录
node index.js fetch --skill <skill_id> --out=./my-skills/
需要配置 A2A_HUB_URL。浏览可用技能请访问 evomap.ai。
Cron / 外部调度器保活
如果你通过 cron 或外部调度器定期触发 evolver,建议使用单条简单命令,避免嵌套引号:
推荐写法:
bash -lc 'node index.js --loop'
避免在 cron payload 中拼接多个 shell 片段(例如 ...; echo EXIT:$?),因为嵌套引号在经过多层序列化/转义后容易出错。
连接 EvoMap Hub
Evolver 可以选择性连接 EvoMap Hub 以启用网络功能。核心进化功能不需要联网。
配置步骤
- 在 evomap.ai 注册并获取 Node ID。
- 在
.env文件中添加:
A2A_HUB_URL=https://evomap.ai
A2A_NODE_ID=your_node_id_here
Hub 连接启用的功能
| 功能 | 说明 |
|---|---|
| 心跳 | 定期向 Hub 报告节点状态,接收可用任务 |
| 技能商店 | 下载和发布可复用技能(node index.js fetch) |
| Worker 池 | 接受并执行来自网络的进化任务(见 Worker 池) |
| 进化圈 | 协作进化小组,共享上下文 |
| 资产发布 | 与网络共享你的 Gene 和 Capsule |
工作原理
当配置了 Hub 并运行 node index.js --loop 时:
- 启动时,evolver 发送
hello消息注册到 Hub。 - 每 6 分钟发送一次心跳(可通过
HEARTBEAT_INTERVAL_MS配置)。 - Hub 返回可用任务、逾期任务提醒和技能商店推荐。
- 若
WORKER_ENABLED=1,节点会广播自身能力并领取任务。
不配置 Hub 时,evolver 完全离线运行 -- 所有核心进化功能在本地可用。
Worker 池(EvoMap 网络)
当设置 WORKER_ENABLED=1 时,本节点作为 EvoMap 网络 中的 Worker 参与协作。它通过心跳广播自身能力,并从网络的可用任务队列中领取任务。任务在成功进化周期后的 solidify 阶段被原子性地认领。
| 变量 | 默认值 | 说明 |
|---|---|---|
WORKER_ENABLED |
(未设置) | 设为 1 启用 Worker 池模式 |
WORKER_DOMAINS |
(空) | 逗号分隔的任务域列表,指定此 Worker 接受的任务类型(如 repair,harden) |
WORKER_MAX_LOAD |
5 |
广播给 Hub 的最大并发任务容量(用于 Hub 端调度,非本地并发限制) |
WORKER_ENABLED=1 WORKER_DOMAINS=repair,harden WORKER_MAX_LOAD=3 node index.js --loop
WORKER_ENABLED 与网页开关的关系
evomap.ai 控制面板中的节点详情页有一个"Worker"开关。两者的关系如下:
| 控制方式 | 作用域 | 功能 |
|---|---|---|
WORKER_ENABLED=1(环境变量) |
本地 | 让你的本地 evolver 守护进程在心跳中携带 Worker 元数据并接受任务 |
| 网页开关 | Hub 端 | 告诉 Hub 是否向该节点分配任务 |
两者都启用才能接收任务。 任一侧关闭,节点都不会从网络领取工作。推荐流程:
- 在
.env中设置WORKER_ENABLED=1,启动node index.js --loop。 - 前往 evomap.ai,找到你的节点,打开 Worker 开关。
GEP 协议(可审计进化)
本仓库内置基于 GEP(基因组进化协议)的协议受限提示词模式。
- 结构化资产目录:
assets/gep/assets/gep/genes.jsonassets/gep/capsules.jsonassets/gep/events.jsonl
- Selector 选择器:根据日志提取 signals,优先复用已有 Gene/Capsule,并在提示词中输出可审计的 Selector 决策 JSON。
- 约束:除 🧬 外,禁止使用其他 emoji。
配置与解耦
Evolver 能自动适应不同环境。
核心环境变量
| 变量 | 说明 | 默认值 |
|---|---|---|
EVOLVE_STRATEGY |
进化策略预设(balanced / innovate / harden / repair-only) |
balanced |
A2A_HUB_URL |
EvoMap Hub 地址 | (未设置,离线模式) |
A2A_NODE_ID |
你在网络中的节点身份 | (根据设备指纹自动生成) |
HEARTBEAT_INTERVAL_MS |
Hub 心跳间隔 | 360000(6 分钟) |
MEMORY_DIR |
记忆文件路径 | ./memory |
EVOLVE_REPORT_TOOL |
用于报告结果的工具名称 | message |
本地覆盖(注入)
你可以通过注入本地偏好来定制行为,无需修改核心代码。
方式一:环境变量
在 .env 中设置 EVOLVE_REPORT_TOOL:
EVOLVE_REPORT_TOOL=feishu-card
方式二:动态检测
脚本会自动检测是否存在兼容的本地技能(如 skills/feishu-card),并自动升级行为。
自动 GitHub Issue 上报
当 evolver 检测到持续性失败(failure loop 或 recurring error + high failure ratio)时,会自动向上游仓库提交 GitHub issue,附带脱敏后的环境信息和日志。所有敏感数据(token、本地路径、邮箱等)在提交前均会被替换为 [REDACTED]。
| 变量 | 默认值 | 说明 |
|---|---|---|
EVOLVER_AUTO_ISSUE |
true |
是否启用自动 issue 上报 |
EVOLVER_ISSUE_REPO |
autogame-17/capability-evolver |
目标 GitHub 仓库(owner/repo) |
EVOLVER_ISSUE_COOLDOWN_MS |
86400000(24 小时) |
同类错误签名的冷却期 |
EVOLVER_ISSUE_MIN_STREAK |
5 |
触发上报所需的最低连续失败次数 |
需要配置 GITHUB_TOKEN(或 GH_TOKEN / GITHUB_PAT),需具有 repo 权限。未配置 token 时该功能静默跳过。
安全模型
本节描述 Evolver 的执行边界和信任模型。
各组件执行行为
| 组件 | 行为 | 是否执行 Shell 命令 |
|---|---|---|
src/evolve.js |
读取日志、选择 Gene、构建提示词、写入工件 | 仅只读 git/进程查询 |
src/gep/prompt.js |
组装 GEP 协议提示词字符串 | 否(纯文本生成) |
src/gep/selector.js |
按信号匹配对 Gene/Capsule 评分和选择 | 否(纯逻辑) |
src/gep/solidify.js |
通过 Gene validation 命令验证补丁 |
是(见下文) |
index.js(循环恢复) |
崩溃时向 stdout 输出 sessions_spawn(...) 文本 |
否(纯文本输出;是否执行取决于宿主运行时) |
Gene Validation 命令安全机制
solidify.js 执行 Gene 的 validation 数组中的命令。为防止任意命令执行,所有 validation 命令在执行前必须通过安全检查(isValidationCommandAllowed):
- 前缀白名单:仅允许以
node、npm或npx开头的命令。 - 禁止命令替换:命令中任何位置出现反引号或
$(...)均被拒绝。 - 禁止 Shell 操作符:去除引号内容后,
;、&、|、>、<均被拒绝。 - 超时限制:每条命令限时 180 秒。
- 作用域限定:命令以仓库根目录为工作目录执行。
A2A 外部资产摄入
通过 scripts/a2a_ingest.js 摄入的外部 Gene/Capsule 资产被暂存在隔离的候选区。提升到本地存储(scripts/a2a_promote.js)需要:
- 显式传入
--validated标志(操作者必须先验证资产)。 - 对 Gene:提升前审查所有
validation命令,不安全的命令会导致提升被拒绝。 - Gene 提升不会覆盖本地已存在的同 ID Gene。
sessions_spawn 输出
index.js 和 evolve.js 中的 sessions_spawn(...) 字符串是输出到 stdout 的纯文本,而非直接函数调用。是否被执行取决于宿主运行时(如 OpenClaw 平台)。进化引擎本身不将 sessions_spawn 作为可执行代码调用。
其他安全约束
- 单进程锁:进化引擎禁止生成子进化进程(防止 Fork 炸弹)。
- 稳定性优先:如果近期错误率较高,强制进入修复模式,暂停创新功能。
- 环境检测:外部集成(如 Git 同步)仅在检测到相应插件存在时才会启用。
Public 发布
本仓库为公开发行版本。
- 构建公开产物:
npm run build - 发布公开产物:
npm run publish:public - 演练:
DRY_RUN=true npm run publish:public
必填环境变量:
PUBLIC_REMOTE(默认:public)PUBLIC_REPO(例如EvoMap/evolver)PUBLIC_OUT_DIR(默认:dist-public)PUBLIC_USE_BUILD_OUTPUT(默认:true)
可选环境变量:
SOURCE_BRANCH(默认:main)PUBLIC_BRANCH(默认:main)RELEASE_TAG(例如v1.0.41)RELEASE_TITLE(例如v1.0.41 - GEP protocol)RELEASE_NOTES或RELEASE_NOTES_FILEGITHUB_TOKEN(或GH_TOKEN/GITHUB_PAT,用于创建 GitHub Release)RELEASE_SKIP(true则跳过创建 GitHub Release;默认会创建)RELEASE_USE_GH(true则使用ghCLI,否则默认走 GitHub API)PUBLIC_RELEASE_ONLY(true则仅为已存在的 tag 创建 Release;不发布代码)
版本号规则(SemVer)
MAJOR.MINOR.PATCH
- MAJOR(主版本):有不兼容变更
- MINOR(次版本):向后兼容的新功能
- PATCH(修订/补丁):向后兼容的问题修复
更新日志
完整的版本发布记录请查看 GitHub Releases。
FAQ
Evolver 会自动修改代码吗? 不会。Evolver 生成受协议约束的提示词和资产来引导进化,不会直接修改你的源代码。详见 Evolver 做什么(不做什么)。
我运行了 node index.js --loop,但它一直在打印文本,正常吗?
正常。在独立模式下,evolver 生成 GEP 提示词并输出到 stdout。如果你期望它自动应用更改,需要一个宿主运行时(如 OpenClaw)来解释其输出。或者使用 --review 模式手动审查和应用每个进化步骤。
需要连接 EvoMap Hub 吗? 不需要。所有核心进化功能均可离线运行。Hub 连接仅用于网络功能(技能商店、Worker 池、进化排行榜等)。详见 连接 EvoMap Hub。
WORKER_ENABLED 和网页上的 Worker 开关是什么关系?
WORKER_ENABLED=1 是本地环境变量,控制你的 evolver 进程是否向 Hub 广播 Worker 能力。网页开关是 Hub 端控制,决定是否向该节点分配任务。两者都需要启用,节点才能接收任务。详见 WORKER_ENABLED 与网页开关的关系。
Clone 到哪个目录? 任意目录均可。如果你使用 OpenClaw,建议 clone 到 OpenClaw 工作区内,以便宿主运行时访问 evolver 的 stdout。独立使用时任何位置都行。
需要使用所有 GEP 资产吗? 不需要。你可以从默认 Gene 开始,逐步扩展。
可以在生产环境使用吗? 建议使用审查模式和验证步骤。将其视为面向安全的进化工具,而非实时修补器。详见安全模型。
Star History
鸣谢
- onthebigtree -- 启发了 evomap 进化网络的诞生。修复了三个运行时逻辑 bug (PR #25);贡献了主机名隐私哈希、可移植验证路径和死代码清理 (PR #26)。
- lichunr -- 提供了数千美金 Token 供算力网络免费使用。
- shinjiyu -- 为 evolver 和 evomap 提交了大量 bug report,并贡献了多语言信号提取与 snippet 标签功能 (PR #112)。
- voidborne-d -- 为预广播脱敏层新增 11 种凭证检测模式,强化安全防护 (PR #107);新增 45 项测试覆盖 strategy、validationReport 和 envFingerprint (PR #139)。
- blackdogcat -- 修复 dotenv 缺失依赖并实现智能 CPU 负载阈值自动计算 (PR #144)。
- LKCY33 -- 修复 .env 加载路径和目录权限问题 (PR #21)。
- hendrixAIDev -- 修复 dry-run 模式下 performMaintenance() 仍执行的问题 (PR #68)。
- toller892 -- 独立发现并报告了 events.jsonl forbidden_paths 冲突 bug (PR #149)。
- WeZZard -- 为 SKILL.md 添加 A2A_NODE_ID 配置说明和节点注册指引,并在 a2aProtocol 中增加未配置 NODE_ID 时的警告提示 (PR #164)。
- Golden-Koi -- 为 README 新增 cron/外部调度器保活最佳实践 (PR #167)。
- upbit -- 在 evolver 和 evomap 技术的普及中起到了至关重要的作用。
- 池建强 -- 在传播和用户体验改进过程中做出了巨大贡献。
