Back to Registry View Author Profile
Official Verified
cross-agent-mailbox
文件信箱方案 - 跨框架Agent通信(适用于任何框架)
skill-install — Terminal
Install via CLI (Recommended)
clawhub install openclaw/skills/skills/ameylover/cross-agent-mailboxOr
📬 Cross-Agent Mailbox - 文件信箱通信
跨框架Agent通信的最简单方案。适用于任何AI框架之间的通信(Hermes、OpenClaw、Claude等)。
核心理念
两个Agent共享一个文件目录,通过写信/读信方式通信。简单、可靠、无依赖。
工作原理
Agent A → 写信到 → shared-mailbox/a-to-b/ → Agent B 读取
Agent B → 写信到 → shared-mailbox/b-to-a/ → Agent A 读取
安装
1. 创建信箱目录
mkdir -p ~/.shared-mailbox/{agent-a-to-b,agent-b-to-a}/{archive}
2. 创建通信协议文件
cat > ~/.shared-mailbox/README.md << 'EOF'
# 跨Agent通信信箱
## 目录结构
- agent-a-to-b/: Agent A 发给 Agent B 的信件
- agent-b-to-a/: Agent B 发给 Agent A 的信件
- archive/: 已处理的信件
## 信件格式
文件名: YYYY-MM-DD_NNN_主题.md
内容: Markdown格式,包含发件人、收件人、时间、内容
EOF
信件格式模板
# 📬 主题
**发件人**:Agent名称
**收件人**:Agent名称
**时间**:YYYY-MM-DD HH:MM
**类型**:通知/回复/请求
---
信件内容...
**签名**
时间
使用方法
发送信件
import os
from datetime import datetime
def send_letter(to_agent, content, subject="通信"):
# 根据目标选择目录
if to_agent == "agent-b":
mailbox = os.path.expanduser("~/.shared-mailbox/agent-a-to-b/")
else:
mailbox = os.path.expanduser("~/.shared-mailbox/agent-b-to-a/")
# 生成文件名
timestamp = datetime.now().strftime("%Y-%m-%d_%H%M")
filename = f"{timestamp}_{subject}.md"
# 写入信件
with open(os.path.join(mailbox, filename), "w") as f:
f.write(content)
return filename
检查新信件
import os
def check_mail(my_mailbox):
"""检查是否有新信件(排除archive目录)"""
mailbox = os.path.expanduser(f"~/.shared-mailbox/{my_mailbox}/")
new_letters = []
for f in os.listdir(mailbox):
if f.endswith(".md") and not f.startswith("."):
new_letters.append(f)
return sorted(new_letters)
归档信件
import shutil
def archive_letter(mailbox, filename):
"""处理完后归档"""
src = os.path.expanduser(f"~/.shared-mailbox/{mailbox}/{filename}")
dst = os.path.expanduser(f"~/.shared-mailbox/{mailbox}/archive/{filename}")
shutil.move(src, dst)
触发机制选择
方案A:定时轮询(简单)
创建cron任务,每5-10分钟检查一次信箱:
# 每5分钟检查
*/5 * * * * cd /path/to/scripts && python3 check_mail.py
优点:简单,任何框架都能用 缺点:有延迟,消耗token
方案B:文件监控(推荐)
使用 watchdog 监控文件变化:
from watchdog.observers import Observer
from watchdog.events import FileSystemEventHandler
class MailHandler(FileSystemEventHandler):
def on_created(self, event):
if event.src_path.endswith(".md"):
print(f"📬 新信件: {event.src_path}")
# 触发处理
observer = Observer()
observer.schedule(MailHandler(), mailbox_path, recursive=False)
observer.start()
优点:实时,几乎零token 缺点:需要常驻进程
通信规范
命名约定
- Agent A → Agent B:
agent-a-to-b/ - Agent B → Agent A:
agent-b-to-a/
文件命名
YYYY-MM-DD_NNN_简短主题.md
例: 2026-04-15_001_打招呼.md
处理流程
- 检查信箱目录
- 读取新信件
- 处理内容
- 回复信件(可选)
- 归档已处理信件
⚠️ 已读机制(必须!避免重复读取)
踩坑经验(2026-04-18):没有已读机制时,每次检查信箱都会重新读取所有历史消息,导致效率低下。
创建已读状态文件
Metadata
AI Skill Finder
Not sure this is the right skill?
Describe what you want to build — we'll match you to the best skill from 16,000+ options.
Find the right skill Add to Configuration
Paste this into your clawhub.json to enable this plugin.
{
"plugins": {
"official-ameylover-cross-agent-mailbox": {
"enabled": true,
"auto_update": true
}
}
}Safety NoteClawKit audits metadata but not runtime behavior. Use with caution.