记忆系统的存储架构
源码路径:src/memdir/paths.ts、src/memdir/memdir.ts
Claude Code 的记忆系统是纯文件的——没有数据库、没有向量存储,只有 Markdown 文件和目录结构。
目录布局
getAutoMemPath()):
CLAUDE_COWORK_MEMORY_PATH_OVERRIDE环境变量(Cowork SDK 全路径覆盖)autoMemoryDirectory设置(仅限policySettings/localSettings/userSettings——故意排除projectSettings,防止恶意仓库将记忆路径指向~/.ssh)- 默认:
<memoryBase>/projects/<sanitized-git-root>/memory/
findCanonicalGitRoot() 找到真正的 .git 根)。
MEMORY.md 索引
MEMORY.md 是记忆的入口索引,每次对话都完整加载到上下文中:
truncateEntrypointContent() 截断并追加警告。设计原因:p97 的索引文件用 200 行就能覆盖,但有些索引条目特别长(p100 观测到 197KB/200 行),字节上限捕捉这种长行异常。
索引条目格式:
MEMORY.md 本身没有 frontmatter——它只是一个链接列表,不是记忆内容。
四类型分类法
源码路径:src/memdir/memoryTypes.ts
记忆被约束为一个封闭的四类型系统,每种类型有明确的 <when_to_save>、<how_to_use> 和 <body_structure> 规范:
| 类型 | 存储内容 | 典型触发 |
|---|---|---|
| user | 用户角色、偏好、技术背景 | ”我是数据科学家”、“我写了十年 Go” |
| feedback | 用户对 AI 行为的纠正和确认 | ”别 mock 数据库”、“单 PR 更好” |
| project | 非代码可推导的项目上下文 | ”合并冻结从周四开始”、“auth 重写是合规要求” |
| reference | 外部系统指针 | ”pipeline bugs 在 Linear INGEST 项目” |
反馈类型的双通道捕获
feedback 类型的 when_to_save 指令特别强调:
Record from failure AND success: if you only save corrections, you will avoid past mistakes but drift away from approaches the user has already validated, and may grow overly cautious.这意味着 AI 不仅在用户说”不要这样做”时保存,也在用户说”对,就是这样”时保存。后一种更难捕捉,但同等重要——它防止 AI 的行为随时间漂移。
每条记忆的 Frontmatter 格式
description 字段是关键:它不是给人读的摘要,而是给 AI 召回系统做相关性判断的搜索关键词。
智能召回机制
源码路径:src/memdir/findRelevantMemories.ts、src/memdir/memoryScan.ts
不是所有记忆都适合每次对话。系统使用一个轻量级 Sonnet 侧查询来筛选最相关的记忆。
召回流程
selectRelevantMemories() 函数,它调用 sideQuery()(一个独立的轻量 API 调用):
近期工具去噪
当 AI 正在使用某个工具时,召回该工具的使用文档是噪音(对话中已有工作上下文)。recentTools 参数让召回系统跳过这些记忆:
已展示去重
alreadySurfaced 参数过滤之前轮次已展示过的文件路径,让 Sonnet 的 5 槽预算花在新的候选上,而不是重复召回同一文件。
记忆注入 System Prompt 的链路
源码路径:src/memdir/memdir.ts → src/context.ts
loadMemoryPrompt() 是记忆注入的入口,每会话调用一次(通过 systemPromptSection('memory', ...) 缓存):
context.ts 中 getSystemContext() 调用时,记忆 Prompt 作为 system prompt 的一个 section 被组装。MEMORY.md 的内容作为 user context message 注入(而非 system prompt),这样可以利用 Prompt Cache 的 prefix 共享。
KAIROS 模式:每日日志
源码路径:src/memdir/memdir.ts(buildAssistantDailyLogPrompt)
长期运行的 assistant 会话使用不同的记忆策略:
- 标准模式:AI 维护
MEMORY.md作为实时索引 + 独立记忆文件 - KAIROS 模式:AI 只往日期文件追加日志(
logs/YYYY/MM/YYYY-MM-DD.md),不做重组
/dream 技能负责将日志蒸馏为主题文件 + MEMORY.md 索引。
记忆漂移防御
源码路径:src/memdir/memoryTypes.ts(TRUSTING_RECALL_SECTION)
记忆可能过期。系统在 Prompt 中设置了一个专门的 section “Before recommending from memory”:
忽略记忆的严格语义
Session Memory 与压缩的联动
源码路径:src/services/compact/sessionMemoryCompact.ts
记忆系统与上下文压缩有深度集成。当 tengu_session_memory 和 tengu_sm_compact 两个 feature flag 同时开启时,压缩优先使用 Session Memory 而非传统摘要: