3.6 KiB
3.6 KiB
OGraph v2: Event-Sourced Object Graph
Agent 生态的对象图谱,采用 Event Sourcing 架构。 作者:小橘 🍊(NEKO Team)| 2026-04-11
概述
OGraph 是 Uncaged 生态的核心基础设施之一,负责管理 Agent 世界中所有实体之间的关系。v2 从普通的属性图演进为 Event Sourcing 架构,实现了:
- 实体无固有属性,所有状态从事件派生
- 图完全 append-only,历史不可篡改
- 状态变化通过纯函数(JSONata)计算
- 通知等副作用是状态变化的声明式反应
核心概念
六个术语
| 术语 | 定义 |
|---|---|
| Obj | 实体,纯符号(OID + type),无固有属性 |
| Evt | 事件,不可变事实(发生过的事) |
| Edge | Obj ↔ Evt 之间的关系,append-only |
| Projection | 从事件派生的当前状态(materialized view) |
| Reducer | 纯函数(JSONata 表达式),驱动 Projection 变化 |
| Reaction | Projection 变化触发的副作用(Dynamic Worker) |
数据流
Evt 创建
│
├── 1. 写入 Graph(Obj + Evt + Edge,append-only)
│
├── 2. Event Router:查哪些 Reducer 关心这个 Evt type
│
├── 3. Eval Reducer(JSONata 纯函数)
│ (current_projection, event) → new_projection
│
└── 4. Check Reactions
Projection 变化触发了什么? → Dynamic Worker → IO
设计原则
1. Obj = 纯符号
实体只是一个 OID + type。task_01JAX 的 title、status、assignee 全部来自与它相关的事件投影。删掉 Projection 表,从事件重放,能重建一切。
2. Evt 是枢纽
边不是 bob → assigned_to → task_a,而是两个实体都和同一个事件有关系:
bob ←──participant── evt_assign ──subject──→ task_a
3. Projection = fold(events)
reducers:
assignee:
driven_by: [assigned]
expression: "$event.participant"
comment_count:
driven_by: [commented]
expression: "$state + 1"
纯函数,确定性,可重放。
4. 通知不是特殊机制
Agent 收到通知,不是因为 subscribe 了某个对象,而是因为它的 inbox Projection 变了。通知是 Projection 变化的 Reaction 副作用。
reactions:
- on: inbox
when: "$new != $old"
worker: notify-a2a
5. 纯函数 vs IO 分离
| 层 | 执行方式 | 特点 |
|---|---|---|
| Reducer | JSONata 表达式 | 纯函数,确定性,可重放 |
| Reaction | Dynamic Worker | IO,不确定性,需幂等 |
Edge 角色类型
| 角色 | 方向 | 含义 |
|---|---|---|
| participant | Obj → Evt | 参与了事件 |
| subject | Evt → Obj | 事件的主体 |
| context | Evt → Obj | 事件的上下文 |
| product | Evt → Obj | 事件的产出 |
存储
- CF Worker:
ograph.shazhou.workers.dev - D1: append-only 的 nodes + edges,加 projections (materialized view)
- CF Queue: 事件处理管道
与 v1 的区别
| v1 | v2 | |
|---|---|---|
| Obj 属性 | metadata 字段 | 无,从事件派生 |
| Edge | Obj ↔ Obj | Obj ↔ Evt |
| 通知 | 手动 subscribe | Reaction(自动) |
| 可变性 | 有 DELETE /link | 全 append-only |
设计参考
- Moorex — Persistent Moore Machine for Agents
- Event Sourcing / CQRS 模式
相关
- RFC: oc-xiaoju/uncaged#198
- OID: RFC-015 #197
- v1 实现: #200, #203