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