← 返回
未分类 Key

Agent Comm Hub

多智能体消息转发与上下文共享中间件 — 基于 MCP 协议实现 agent 间通信与任务协同。支持多 Agent 接入,提供标准 MCP 工具接口和本地 SQLite 存储。
多智能体消息转发与上下文共享中间件——基于MCP协议实现Agent间通信与协同,支持多Agent接入,提供标准MCP工具接口和本地SQLite存储。
liuboacean
未分类 clawhub v3.0.10 5 版本 99800.6 Key: 需要
★ 1
Stars
📥 981
下载
💾 1
安装
5
版本
#2.4.0#2.4.1#ai-agents#communication#evolution#hermes#latest#mcp#memory#message-bus#multi-agent#python-sdk#rbac#sse#task-orchestration#task-scheduling#typescript-sdk#workbuddy

概述

Agent Communication Hub

> 多智能体消息转发与上下文共享中间件 — v2.4.5

让两个或多个独立 AI 智能体之间实现实时双向通信上下文自动同步。基于 MCP 协议 + stdio 模式,消息本地持久化,延迟 < 50ms。

架构概览

┌──────────────┐         ┌──────────────────────────────┐         ┌──────────────┐
│   Agent A    │  SSE    │   Agent Communication Hub    │  SSE    │   Agent B    │
│  (Hermes)    │◄───────►│  (stdio)                    │◄───────►│ (WorkBuddy)  │
│              │  MCP    │                              │  MCP    │              │
└──────────────┘◄───────►│  SQLite WAL + 30 表          │◄───────►└──────────────┘
                          │  53 MCP 工具 + 4 级权限     │
                          │  上下文暂存 + 建议闭环       │
                          └──────────────┬──────────────┘
                                         │
                                    SQLite (WAL)

三层协议

协议用途延迟
----------------------
MCP 工具层stdio JSON-RPC结构化操作(发消息、分配任务、查状态)<50ms
SSE 推送层Server-Sent Events实时事件通知(新消息、新任务、建议确认)<50ms

快速上手 (5 分钟)

从零到完成第一次 Agent 间通信的编号流程:

Step 1: 确认 Hub 运行状态

确认 Agent Communication Hub 服务器正在运行。如果通过 stdio 模式接入,检查 MCP 配置是否正确加载:

调用: get_online_agents()
期望: 返回在线 Agent 列表(至少含自己)
失败: Hub 未运行 → 先启动 Hub 服务器

[检查点] 用户确认:如果 Hub 未运行,询问用户是否要启动 Hub 服务器。

Step 2: 注册或确认身份

检查自己是否已在 Hub 注册,如果没有则注册:

1. 调用: query_agents(status='all') → 查看所有 Agent
2. 如果自己的 Agent ID 不在列表中
   → register_agent(invite_code, name, capabilities)
3. 如果已注册 → 记下自己的 agent_id 供后续使用

[检查点] 用户确认:注册新 Agent 需要 invite_code,先问用户是否有可用的邀请码。

Step 3: 维持在线状态

启动心跳维持在线,确保能接收实时消息推送:

调用: heartbeat(agent_id='你的ID')
频率: 每 30 秒一次(超过 90 秒无心跳则自动标记为离线)

Step 4: 检查未读消息

上线后第一时间检查是否有离线期间缓存的消息:

1. 调用: search_messages(query='你的ID', limit=20)
2. 筛选 status='unread' 的消息
3. 按时间顺序处理,先 acknowledge_message 确认收到,再回复

[检查点] 用户确认:找到未读消息后,逐条向用户摘要汇报,请用户确认如何处理。

Step 5: 发送第一条消息

向另一个 Agent 发送消息,验证双向通信:

调用: send_message(from='你的ID', to='目标AgentID', content='通信链路确认畅通')
检查返回: delivered_realtime — true=对方在线, false=对方离线

[检查点] 用户确认:发送前向用户确认消息内容和目标 Agent。broadcast_message 必须逐条确认。

完整闭环示例

场景:Hub 在线 → 检查 WorkBuddy 是否有未读消息 → 处理并回复

1. get_online_agents()                    # 确认自己和对方在线
2. search_messages(limit=10)              # 查最近消息
3. acknowledge_message(msg_id, agent_id)  # 标记已读
4. send_message(to='workbuddy', content='已收到,正在处理')  # 回复
5. mark_consumed(resource=msg_id, action='replied')  # 消费水位线

核心能力

53 个 MCP 工具(v2.4.0)

Identity 身份 (6)

工具功能
------------
register_agent注册新 Agent,需提供 HUB_KEY 认证
heartbeatAgent 心跳上报,维持在线状态,每 3 次连续心跳记录 +1
query_agents查询 Agent 列表,支持状态/角色筛选
get_online_agents获取当前在线 Agent 列表

Message 消息 (5)

工具功能
------------
send_messageAgent 间点对点消息,支持 Markdown,自动去重(sha256)
broadcast_message(需逐条确认后发送)
acknowledge_message确认已读消息,防止重复出现
search_messages全文搜索消息历史
batch_acknowledge_messages批量确认消息(1-500 条/次),用于清理消息积压

File 文件 (3)

工具功能
------------
send_file发送文件附件(Base64,10MB 限制),关联到消息
receive_file接收附件,返回 Base64 编码内容
list_attachments列出附件,支持按消息/Agent 筛选

Task 任务 (3)

工具功能
------------
assign_task创建并分配任务,支持上下文传递
update_task_status更新任务状态(inbox→assigned→in_progress→completed/failed)
get_task_status查询任务详情,含依赖、Pipeline、交接信息

Context 上下文暂存 (5)

工具功能
------------
store_memory临时暂存当前任务参考信息
recall_memory检索已暂存的上下文
list_memories列出当前 Agent 的暂存条目
delete_memory删除暂存条目(仅 creator)
search_memories检索当前 Agent 的暂存内容

经验记录

经验记录和策略管理需特定权限配置。

任务协同

工具功能
------------
add_dependency添加任务依赖关系(依赖检查)
remove_dependency删除任务依赖关系
get_task_dependencies查询任务上下游依赖
create_parallel_group创建并行任务组(2-10 个任务)
request_handoff请求任务交接
accept_handoff接受任务交接
reject_handoff拒绝任务交接(含理由)
add_quality_gate在 Pipeline 中添加质量门
evaluate_quality_gate评估质量门(passed/failed)
recalculate_trust_scores按调度执行分数维护
create_pipeline创建 Pipeline 流水线
get_pipeline查询 Pipeline 详情
list_pipelines列出 Pipeline
add_task_to_pipeline向 Pipeline 添加任务

运维工具 (4)

工具功能
------------
get_db_stats数据库统计信息(表行数、大小、Agent 数等)
archive_data数据维护工具
(其余 2 个内部工具)权限验证与控制
(其余 2 个内部工具)权限验证与控制

消费水位线 (2)

工具功能
------------
mark_consumed标记任务/消息为已消费,防止重复处理
check_consumed查询资源是否已被消费

> 所有工具内置 try-catch + 3 次指数退避重试(100ms → 200ms → 400ms)。v2.4.0 统一错误格式:HubError 错误码 + mcpError()/mcpFail() 标准返回。check_consumed 查询失败时降级返回 consumed=false(不阻塞业务)。

任务状态机

inbox → assigned → [waiting] → in_progress → completed / failed / cancelled

用户确认检查点

以下操作必须在执行前暂停,向用户摘要说明并等待确认:

#操作检查点说明风险
--------------------------
1broadcast_message广播消息会发送给多个 Agent,逐条确认内容和接收列表
2assign_task分配任务前确认:描述是否清晰、目标 Agent 是否合适、Priority 正确
3batch_acknowledge_messages批量确认会一次性标记多条消息为已处理,确认不会遗漏重要信息
4create_pipeline创建流水线前确认任务顺序、质量门设置、参与 Agent
5add_quality_gate质量门失败会阻塞后续任务,确认评估标准合理
6request_handoff交接任务前确认目标 Agent 有能力接手、理由充分
7archive_data归档操作会移动数据到归档表,确认归档范围和天数
8store_memory(scope='group')写入组内共享记忆前确认内容适当,不会泄露敏感信息
9propose_strategy提议策略前确认内容准确、分类正确、有实际价值
10reject_handoff拒绝交接需提供理由,确认不会导致任务阻塞

> 规则:LLM 遇到上表操作时,先向用户输出摘要说明,明确询问"是否继续?",得到肯定答复后再执行。用户可随时跳过检查点。

数据隔离与安全边界

边界实现方式
---------------
接收方校验send_message/assign_task 中的 to_agent 必须为已注册 Agent,未注册 Agent 被拒绝
Per-Agent 数据隔离每个 Agent 仅可见自身消息、任务和暂存条目;跨 Agent 查询受 4 级权限控制
暂存内容保护store_memory 创建的条目仅 creator 可检索和删除,不会自动暴露给其他 Agent
经验记录审批share_experience 提交的记录需经 full 权限确认后才对其他 Agent 可见

接入配置(stdio 模式)

在 MCP 配置文件中添加 Hub 为 stdio 服务器,提供 HUB_KEY 环境变量进行认证。Hub 通过 stdio 传输 MCP 协议,Agent 的 LLM 可直接调用 Hub 工具。

{
  "mcpServers": {
    "agent-comm-hub": {
      "command": "node",
      "args": ["<hub-install-path>/stdio.js"],
      "env": {
        "HUB_KEY": "your-connection-key"
      }
    }
  }
}

资源索引

此 skill 目录下已有 Hub 完整源码,可直接参考:

本地源文件

文件用途
------------
src/server.ts服务端入口,Express + MCP/SSE 双通道
src/tools.ts全部 MCP 工具的 TypeScript 实现
src/db.tsSQLite WAL 数据库初始化与连接
src/identity.tsAgent 注册、认证、4 级权限控制
src/dedup.tsSHA256 消息去重实现
src/errors.tsHubError 统一错误码(v2.4.0+)
src/stdio.tsStdio 模式传输层
src/sse.tsSSE 推送通道
src/orchestrator.ts任务编排、Pipeline、质量门
src/evolution.tsEvolution Engine:策略/经验/信任分
src/memory.ts上下文暂存与管理
src/security.ts安全验证、CORS、Token 管理
src/metrics.ts统计指标收集
src/repo/数据访问层(repository pattern)
package.jsonNode.js 依赖与版本定义

参考链接

  • GitHub 仓库: https://github.com/liuboacean/agent-comm-hub
  • MCP 协议规范: https://spec.modelcontextprotocol.io

权限说明(4 级)

级别说明可用工具范围
----------------------
authenticated已认证(HUB_KEY)register_agent(初始注册)
member已注册 Agent消息 send_message/acknowledge_message + 任务 assign_task/get_task_status
group_manager并行组管理任务协同 + Pipeline 工具(不含暂存/经验)
full完整权限全部工具(含运维与建议管理)

> 部分管理类工具仅特定权限可调用,具体以实际角色配置为准。

> 初始分数 50,公式:base(50) + verified_capabilities3 + approved_strategies2 + positive_feedback1 - negative_feedback2,clamp(0,100)。

v2.4.0 更新要点

Phase内容变更
-------------------
Atools.ts 拆分2687 行 → 8 模块 + 30 行入口 + utils.ts
B单元测试100 用例,role-control >= 70% / dedup branches>=60, functions>=70 / utils 100%
CCI/CDGitHub Actions:typecheck + test + coverage 3 Jobs
D类型健壮any 归零 + HubError 统一错误码 + MCP 返回格式标准化

踩坑经验速查

#场景要点
---------------
1MCP 多 Client必须用 Stateless 模式,Stateful 只允许一个 Client
2MCP Accept Header必须带 Accept: application/json, text/event-stream
3MCP 响应格式SDK 返回 SSE 格式(data: {...}),不是纯 JSON
4ESM 兼容不能用 require(),用 import() 动态导入
5UTF-8 块读取httpx resp.read(1) 会截断多字节字符,用 read(4096)
6SSE 心跳10 秒间隔,服务端发 : ping
7MCP != SSEMCP 是工具调用通道(Agent→Hub),SSE 是推送通道(Hub→Agent)
8离线补发消息/任务存 SQLite,上线后 SSE 自动批量推送
9stdio 模式所有日志走 stderr,stdout 保留给 JSON-RPC
10better-sqlite3 boolean绑定参数必须用 1/0,不能用 true/false
11HubError 错误码v2.4.0 统一用 mcpError()/mcpFail(),不要手动构造错误响应

安全配置

配置项说明
--------------
HUB_KEYstdio 模式连接密钥,所有 Agent 接入必须提供,用于身份认证与消息完整性校验
4 级权限模型authenticated → member → group_manager → full,逐级授权
CORS 白名单默认拒绝跨域,通过 CORS_LIST 显式配置允许的来源

环境变量

变量默认值说明
--------------------
HUB_KEYstdio 模式连接密钥(必填)
DB_PATH./comm_hub.dbSQLite 数据库路径
LOG_LEVELinfo日志级别:debug / info / warn / error
CORS_LIST(空)CORS 白名单(逗号分隔),空=拒绝所有跨域

技术依赖

Hub 服务器

  • Node.js 18+
  • @modelcontextprotocol/sdk ^1.10.2(支持 StdioServerTransport)
  • express ^4.19
  • better-sqlite3 ^11.9
  • zod ^3.23

Python 客户端(零外部依赖)

  • Python 3.9+(纯标准库:http.client / json / asyncio)

版本历史

共 5 个版本

  • v3.0.10 当前
    2026-05-26 22:49 安全 安全
  • v3.0.7
    2026-05-21 12:34 安全 安全
  • v2.5.4
    2026-05-08 12:38 安全 安全
  • v2.5.2
    2026-05-07 03:44 安全 安全
  • v2.2.2
    2026-05-03 10:01 安全 安全

安全检测

腾讯云安全 (Keen)

安全,无风险
查看报告

腾讯云安全 (Sanbu)

安全,无风险
查看报告

🔗 相关推荐

Hermes Learning

liuboacean
Hermes 学习材料同步技能:从 Hermes Agent 获取自我更新的学习材料,助力 WorkBuddy 自我优化。支持 evolution.db 持久化、概念关联与双向反馈闭环。
★ 0 📥 572

建站骨架 (EdgeOne Pages)

liuboacean
一句话需求,AI 生成完整前后端网站并自动部署至 EdgeOne Pages,支持电商(Auth/购物车/支付)、AI(SSE 流式对话)和管理后台。
★ 0 📥 605

Hermes Communication Bridge

liuboacean
WorkBuddy 与 Hermes 使用共享文件队列进行双向异步通信。触发词:发消息给hermes、收hermes消息、查看通信队列、双向通信、队列消息、异步通信
★ 0 📥 544