ClaudeCode 消息系统(一)uuid 和 parent-uuid

  • 生成
    • 每条消息的uuid:主agent的消息模块,每次生成一条新消息的时候,用UUID v4生成的,全局唯一
    • parent-uuid:同样是UUID v4,生成消息的时候,指向这条消息的父消息,也就是上一条消息的uuid,用来构建会话的链路
  • 谁来生成:主agent的消息模块,每次生成新消息的时候自动生成
  • 怎么触发生成:每次有新的消息(用户输入、模型输出、工具结果),都会自动生成这两个id
  • 存储到了哪里 :存储到了会话的JSONL日志文件里,每条消息都有这两个字段,日志文件在~/.claude/transcripts/下,按会话分文件
  • 会被用来怎么用
    1. 增量提取记忆:用lastMemoryMessageUuid(也就是parent-uuid)做游标,记录上次提取到哪条消息,这次只处理新的消息,避免重复提取
    2. 会话链路追溯:用parent-uuid构建会话树,追溯消息的父子关系,恢复会话的历史
    3. 互斥检查:如果用户已经显式写了记忆,就跳过自动提取,避免覆盖
  • JSONL的记录
    • 是的,JSONL会把给大模型的内容全部记录下来,包括CLAUDE.md、Session Memory的内容,所有的系统提示、用户消息、模型输出、工具结果,都会记录到JSONL里
  • 和三个记忆的关系
    1. Auto Memory:用parent-uuid做游标,增量提取记忆,避免重复处理
    2. Session Memory:用parent-uuid做游标,增量更新会话记忆,每增长5K token更新一次
    3. AutoDream:用parent-uuid做游标,读取会话的JSONL日志,提取新的信号,整理记忆

7. 团队记忆同步的细节

  • 本地的CLAUDE.md不会自动同步给团队,本地的CLAUDE.md是用户的个人文件,只有团队的CLAUDE.md才会同步:
  • 团队同步的流程
    1. 本地优先:先加载本地的团队记忆文件,保证离线可用
    2. 远程同步:通过REST API,和服务器同步,用304缓存判断远程的文件有没有更新,避免重复下载
    3. Delta上传:如果本地的团队记忆有更新,就上传Delta变更,不是全量上传
    4. 乐观锁:用乐观锁解决冲突,多人同时修改的时候,保证数据的一致性
  • 本地的团队记忆目录 :是的,本地有~/.claude/projects/{项目hash}/memory/team/目录,里面是团队的记忆文件
  • 同步的方向:是先改了本地的团队目录的文件,然后同步到远端服务器,然后其他成员拉取更新,不是本地的个人CLAUDE.md同步,是团队的共享记忆。
相关推荐
摸鱼同学8 分钟前
04-Embedding 和向量数据库:让机器真正理解语义
ai·chatgpt·embedding·agent·向量数据库
人工智能培训1 小时前
打造行业知识图谱三步走
大数据·人工智能·机器学习·3d·知识图谱·agent
十正3 小时前
Claude code源码精读之蜂群模式
javascript·人工智能·agent·claude code
陈如水3 小时前
Agent Skill
agent
谢白羽4 小时前
SimpleMem:长期记忆不是存得更多,而是让每个 token 更有信息密度
大模型·llm·agent·agent memory
ckjoker4 小时前
四大AI Agent架构拆解:我手敲了一个迷你版,发现了7条可迁移的设计原则
python·agent
冬奇Lab6 小时前
Agent 系列(14):Agent 可观测性——追踪每一步决策,让黑盒变透明
人工智能·llm·agent
JouYY7 小时前
如何为基于 WebSocket 的 AI Agent 构建自动化测评系统
llm·agent·ai编程
AI语宙漫游指南7 小时前
Memory-os 7 层记忆架构深度解析:让 Hermes Agent 真正 “记住并使用“ 知识
人工智能·agent
七夜zippoe8 小时前
OpenClaw Nodes 设备管理深度解析:AI Agent的跨设备协作能力
人工智能·ai·agent·openclaw·nodes