Install
openclaw skills install mem0-memory-setup为 Hermes Agent 配置 Mem0 外部记忆层。涵盖 pip install、npm CLI 安装、 Agent Mode 注册、Hermes 集成、账号认领、验证、和国内网络/特殊 shell 的排错。 使用场景:用户问"怎么给 Hermes 加记忆"、"装一下 mem0"、"配置外部记忆"、 "memory provider"、"让 Hermes 记住我"。
openclaw skills install mem0-memory-setupMem0("mem-zero")是开源的 AI Agent 记忆层(Apache 2.0)。Hermes 内置 8 种记忆 provider,其中 Mem0 支持服务端自动事实提取 + 语义搜索 + 实体提权,一行命令接入。
官方文档: https://docs.mem0.ai Hermes 集成文档: https://hermes-agent.nousresearch.com/docs/user-guide/features/memory-providers GitHub: https://github.com/mem0ai/mem0
hermes memory status 显示 provider 为 built-in onlypip install mem0ai
中国用户(镜像加速):
pip install mem0ai -i https://pypi.tuna.tsinghua.edu.cn/simple
python3 -c "from mem0 import Memory; print('Mem0 lib OK')"
# → Mem0 lib OK
Mem0 CLI (@mem0/cli) 用于注册 Agent Mode 账号和获取 API Key:
npm install -g @mem0/cli
如果报 EACCES(权限错误):
npm 默认 prefix 是 /usr,普通用户没有写入权限。不要用 sudo,改为用户目录:
# 检查当前 prefix
npm config get prefix # 很可能返回 /usr
# 设为用户目录(只需一次,永久生效)
npm config set prefix ~/.npm-global
# 重新安装
npm install -g @mem0/cli
重要:保持 prefix 为
~/.npm-global,不要改回/usr。 这条设定对所有 npm 全局包(mmx-cli、@mem0/cli 等)都生效,改完后所有npm install -g都不再需要 sudo。永久解决 EACCES 问题。
CLI 装在 ~/.npm-global/bin/mem0。bash 通过 .bashrc 加 PATH:
export PATH="$HOME/.npm-global/bin:$PATH"
fish shell(通过 .bashrc 启动 fish): 如果 .bashrc 中有上面这行,fish 会继承继承过来的 PATH。验证用:
type mem0
# → mem0 is /home/po/.npm-global/bin/mem0
如果找不到,在 ~/.config/fish/config.fish 添加:
fish_add_path ~/.npm-global/bin
AI Agent 可以直接注册,无需人类邮箱:
mem0 init --agent --agent-caller hermes
说明:
--agent-caller hermes — 告诉 Mem0 这是 Hermes Agent~/.mem0/config.json 保存 API Keypython3 -c "import json; print(json.load(open('/home/po/.mem0/config.json'))['platform']['api_key'])"
或直接查看:cat ~/.mem0/config.json
写入 API Key 到 .env:
MEM0_KEY=$(python3 -c "import json; print(json.load(open('$HOME/.mem0/config.json'))['platform']['api_key'])")
echo "export MEM0_API_KEY=$MEM0_KEY" >> ~/.hermes/.env
设置 provider:
hermes config set memory.provider mem0
hermes memory status
# → Plugin: installed ✓
# → Status: available ✓
# → Provider: mem0 ← active
mem0 add "Test memory: user prefers concise responses"
mem0 search "prefers concise"
# → Found 1 memories:
# → User prefers concise responses in conversations
# → Score: 0.34
让人类用户认领 Agent 账号,获得 Web 面板和管理权限:
mem0 init --email <your-email>
# 输入邮箱验证码即可
# API Key 不变,所有记忆数据保留
认领后可在 app.mem0.ai 查看记忆数据和管理面板。
| 时机 | 行为 |
|---|---|
| 每轮对话前 | Mem0 预取相关记忆注入 system prompt(零延迟,后台完成) |
| 每轮回复后 | Mem0 自动提取事实并存储(后台线程,不阻塞对话) |
| 会话结束时 | 服务端处理存储优化和去重 |
| Circuit breaker | 连续 5 次失败后暂停 2 分钟,Agent 继续工作不受影响 |
启用 Mem0 后,Hermes 额外获得 3 个工具(自动调用,无需手动触发):
| 工具 | 功能 |
|---|---|
mem0_profile | 获取所有已存储的用户记忆 |
mem0_search | 语义搜索(支持 rerank + top_k 过滤) |
mem0_conclude | 手动存储一条事实(不走服务端提取) |
内置记忆(memory/user 工具)始终并行运行,不受影响:
内置记忆: MEMORY.md + USER.md 文件 → 2 个分区,各 2200 字符上限
Mem0: 云端语义向量库 → 无大小限制,支持语义搜索 + 自动提取
两者互补:内置记忆存静态事实(项目路径、设备参数、偏好),Mem0 存动态学习(用户习惯、工作模式、历史偏好变化)。
-i https://pypi.tuna.tsinghua.edu.cn/simplemem0 命令找不到# 检查安装位置
ls ~/.npm-global/bin/mem0
ls /usr/lib/node_modules/.bin/mem0
# 加 PATH
export PATH="$HOME/.npm-global/bin:$PATH"
检查以下 env var 是否已设置:
grep MEM0_API_KEY ~/.hermes/.env
npm 默认 prefix 为 /usr,普通用户无写入权限。解法:
npm config set prefix ~/.npm-global
# 之后安装无需 sudo
fish 没有 which 命令。用内置的 type 代替:
type mem0
# → mem0 is /home/po/.npm-global/bin/mem0
向 memory 工具写入 .env 路径、API Key 明文等敏感信息会触发安全模式 hermes_env 导致写入被拒绝。不要在 memory 条目中包含 .env、api_key、token、secret 等字样的路径或值。
解法:将敏感配置步骤写在 SKILL.md 中(不注入 system prompt),只在 memory 中记录无风险的事实(如 "Mem0 已配置"、"provider: mem0" 等摘要)。