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同步,是团队的共享记忆。
相关推荐
xueyongfu5 分钟前
从一次 Hermes Agent 会话看 System Prompt、Tools 和 Skills
agent·openclaw·hermes
zavoryn1 小时前
Tool Use 不是给大模型装插件,而是在设计 Agent 的执行权限系统
agent
特立独行的猫a1 小时前
轻量级 AI 编码新力量| AtomCode Air 完全指南:用自然语言编程,让创意即时落地
人工智能·ai·agent·使用指南·atomcode·atomcode air
PersonalViolet1 小时前
拒绝黑箱:从 OpenAI API 协议看 Agent 是如何长出“手脚”的
agent
付玉祥1 小时前
Agent 不只是会调用工具:Echo Agent 的认知级记忆系统解析
agent
xuco1 小时前
如何让流式输出的 Markdown 渲染更丝滑
前端·agent
SuAluvfy2 小时前
不存在“全能第一模型”,存在“任务空间中的局部最优模型”
人工智能·chatgpt·agent
闲人编程3 小时前
Agent的安全边界:如何防止AI失控(对齐问题)
网络·python·ai·agent·权限·智能体·cai
小李子呢021115 小时前
什么是MCP?
agent
Mr. zhihao17 小时前
Agentic 知识库:Agent Wiki不是取代向量数据库,而是让 Agent 学会“多模态思考”
数据库·agent·angetic