Personal Memory System
概述
这是一个为 OpenClaw 设计的个人知识管理技能。它解决了“人类记忆不可靠”的核心问题,通过自动化流程,将你最重要的想法和决策从易遗忘的 Markdown 文本,转化为机器可查询的结构化数据库。
工作原理
- 输入:你将重要的洞察、决策、经验写入
/home/awu/.openclaw/workspace-work/MEMORY.md文件,使用###标题分隔不同主题。 - 同步:每当 OpenClaw 的心跳(heartbeat)被触发,
auto_sync_memory.py脚本会自动运行。 - 处理:脚本读取
MEMORY.md,将每个###标题及其下的内容解析为一条数据库记录。 - 输出:这些记录被写入
/home/awu/.openclaw/workspace-work/memory.dbSQLite 数据库。 - 查询:当你提出自然语言问题(如“我过去对 AI 模型的看法?”),AI 助手会调用
query_memory.py脚本,该脚本会将问题转换为 SQL 查询,从memory.db中精准检索出所有相关记忆,并为你生成一个自然语言的总结性回答。
系统组件
MEMORY.md:你的个人长期记忆库,人类可读,可版本控制。memory.db:自动同步的 SQLite 数据库,机器可查询。auto_sync_memory.py:核心同步脚本,由 OpenClaw 心跳机制调用。query_memory.py:智能查询脚本,负责将自然语言问题转换为 SQL 查询并生成回答。obsidian-vault/:你的 Obsidian 知识库,所有笔记的原始来源。git_sync_on_save.sh:后台守护进程,每10秒检查 Obsidian 知识库变更,自动执行 git add/commit/push。git_sync.log:记录所有 Git 同步事件的日志文件,用于审计和故障排查。
安装与使用
- 安装:将此技能包放入 OpenClaw 的
skills目录,或通过clawhub install awublack-personal-memory-system安装。 - 初始化:确保你的工作区根目录下存在以下文件和目录:
MEMORY.mdobsidian-vault/git_sync_on_save.shgit_sync.logauto_sync_memory.pyquery_memory.py
- 运行:确保
git_sync_on_save.sh已通过nohup ./git_sync_on_save.sh > git_sync.log 2>&1 &启动并常驻后台。- 检查:
ps aux | grep git_sync_on_save.sh - 重启:
pkill -f git_sync_on_save.sh && nohup ./git_sync_on_save.sh > git_sync.log 2>&1 &
- 检查:
- 查询:直接向 AI 助手提问,例如:“我过去对 Obsidian 的看法是什么?” 系统会自动调用
query_memory.py脚本检索并回答。
安全与隐私
- 完全本地化:所有数据(
MEMORY.md,memory.db,query_memory.py,obsidian-vault/,git_sync_on_save.sh,git_sync.log)均存储在你的本地工作区,不上传、不共享。 - 无外部依赖:不调用任何网络 API,不访问云服务。
- 可审计:所有操作均在你的控制之下,你可以随时查看所有相关文件的内容。
- 三重冗余:你的记忆存在于三个独立位置:
- 本地工作区:MEMORY.md, memory.db, git_sync_on_save.sh
- Obsidian 知识库:/home/awu/.openclaw/workspace-work/obsidian-vault/
- 远程 Git 仓库:https://github.com/awublack/obsidian-vault 任何一处损坏,其他两处均可恢复,记忆永不丢失。
未来扩展
- 与 Obsidian 的双向链接功能集成,自动生成知识图谱。
- 每日自动生成
memory/YYYY-MM-DD.md的摘要。 - 支持导出
memory.db为 CSV 或 JSON 以供备份。 - 使用更先进的 NLP 模型(如本地小模型)来增强
query_memory.py的语义理解能力。
“记忆不是用来记住的,是用来被访问的。” —— 你的数字大脑