- 生成 :
- 每条消息的
uuid:主agent的消息模块,每次生成一条新消息的时候,用UUID v4生成的,全局唯一 parent-uuid:同样是UUID v4,生成消息的时候,指向这条消息的父消息,也就是上一条消息的uuid,用来构建会话的链路
- 每条消息的
- 谁来生成:主agent的消息模块,每次生成新消息的时候自动生成
- 怎么触发生成:每次有新的消息(用户输入、模型输出、工具结果),都会自动生成这两个id
- 存储到了哪里 :存储到了会话的JSONL日志文件里,每条消息都有这两个字段,日志文件在
~/.claude/transcripts/下,按会话分文件 - 会被用来怎么用 :
- 增量提取记忆:用
lastMemoryMessageUuid(也就是parent-uuid)做游标,记录上次提取到哪条消息,这次只处理新的消息,避免重复提取 - 会话链路追溯:用parent-uuid构建会话树,追溯消息的父子关系,恢复会话的历史
- 互斥检查:如果用户已经显式写了记忆,就跳过自动提取,避免覆盖
- 增量提取记忆:用
- JSONL的记录 :
- 是的,JSONL会把给大模型的内容全部记录下来,包括CLAUDE.md、Session Memory的内容,所有的系统提示、用户消息、模型输出、工具结果,都会记录到JSONL里
- 和三个记忆的关系 :
- Auto Memory:用parent-uuid做游标,增量提取记忆,避免重复处理
- Session Memory:用parent-uuid做游标,增量更新会话记忆,每增长5K token更新一次
- AutoDream:用parent-uuid做游标,读取会话的JSONL日志,提取新的信号,整理记忆
7. 团队记忆同步的细节
- 本地的CLAUDE.md不会自动同步给团队,本地的CLAUDE.md是用户的个人文件,只有团队的CLAUDE.md才会同步:
- 团队同步的流程 :
- 本地优先:先加载本地的团队记忆文件,保证离线可用
- 远程同步:通过REST API,和服务器同步,用304缓存判断远程的文件有没有更新,避免重复下载
- Delta上传:如果本地的团队记忆有更新,就上传Delta变更,不是全量上传
- 乐观锁:用乐观锁解决冲突,多人同时修改的时候,保证数据的一致性
- 本地的团队记忆目录 :是的,本地有
~/.claude/projects/{项目hash}/memory/team/目录,里面是团队的记忆文件 - 同步的方向:是先改了本地的团队目录的文件,然后同步到远端服务器,然后其他成员拉取更新,不是本地的个人CLAUDE.md同步,是团队的共享记忆。