16 KiB
多层级任务组织最佳实践调研报告
调研日期:2026-05-17 调研目的:为 moziplus v2 三级任务层次(Project / Card(Epic) / Task)设计提供业界参考 调研范围:项目管理工具、AI Agent 编排系统、黑板架构、数据库模型
一、项目管理工具的层级组织
1.1 Jira 的层级模型
层级结构:
Project → Epic → Story/Bug/Task → Sub-task
Jira 支持自定义层级扩展(Premium/Enterprise),标准配置为 3-4 层。Jira 8+ 允许在 Epic 上方增加 Initiative、Theme 等层级。
数据库设计要点:
- 单表 +
project_id过滤:Jira 的核心表是jiraissue,所有 issue 类型(Epic/Story/Task/Sub-task)存储在同一张表,通过issuetype字段区分 - 层级通过
parent_id+topmost_issue_id实现:每个 issue 有parent_id指向上级,topmost_issue_id指向层级树的根节点 - Project 是隔离边界:Project 持有独立的 workflow、permission scheme、notification scheme 配置,但数据物理上共享表
- 多租户隔离策略:小租户用共享 schema(加
tenant_id),大企业客户可提供独立 schema 或独立数据库实例
关键洞察:
Jira 选择"单表存所有 issue + 类型字段区分 + project_id 隔离"的模型。这说明在项目管理领域,灵活的类型系统比物理隔离更重要。Project 是逻辑隔离边界,不是物理隔离边界。
1.2 Linear 的层级模型
层级结构:
Workspace → Team → Project → Issue(可设 parent issue)
Linear 更扁平,没有原生的 Epic 概念,而是通过"Project"(时间框定的倡议)+ Issue 的 parent/child 关系来实现层级。
数据库设计要点:
- Workspace 级共享数据库:一个 Workspace 对应一个数据库实例(或共享实例+行级隔离)
- Team 是主要的分组单元:每个 Team 有自己的 Issue 列表视图
- Project 是跨 Team 的聚合:一个 Project 可以包含多个 Team 的 Issue
- UUID + organization_id 行级隔离:类似 SaaS 标准做法
1.3 Asana 的层级模型
层级结构:
Workspace/Organization → Project → Section → Task → Subtask
Asana 支持多项目(Portfolio/Program)聚合,Section 作为 Task 的分组。
数据库设计要点:
- 共享数据库 + 行级隔离:所有 workspace 共享同一个数据库,通过
workspace_id过滤 - Task 是核心实体:Project、Section 都是 Task 的"容器标签",而非独立实体
- 多对多关系:一个 Task 可以属于多个 Project(通过
project_membership关联表)
1.4 小结:项目管理工具的共同模式
| 工具 | 层级数 | DB 隔离边界 | 类型区分方式 |
|---|---|---|---|
| Jira | 3-7 层(可扩展) | Project(逻辑隔离) | 单表 + issuetype 字段 |
| Linear | 3-4 层 | Workspace | 单表 + parent 关系 |
| Asana | 4-5 层 | Workspace | 单表 + 容器标签 |
核心结论:项目管理工具几乎都采用"单表存所有任务 + 类型/层级字段区分 + 逻辑隔离"的模型,而非物理隔离。
二、AI Agent 编排系统的多层级任务组织
2.1 LangGraph
层级组织方式:
- Graph → Subgraph → Node:LangGraph 通过嵌套的 StateGraph 实现层级
- State 是核心:每个 Graph 有自己的 State schema,Subgraph 可以有独立的 State
- State 传递机制:
- 父 Graph 的 State 可以通过
state_schema映射传递给 Subgraph - Subgraph 执行完毕后,State 可以回传给父 Graph
- 使用
thread_id实现持久化,同一thread_id下的 State 共享持久化存储
- 父 Graph 的 State 可以通过
共享上下文 vs 隔离:
- 默认行为:Subgraph 的 State 是隔离的,需要显式映射才能与父 Graph 共享
- 共享策略:通过 State 的 key 映射(
state_key_mapping)实现有限共享 - 持久化:通过 Checkpointer(MemorySaver / SqliteSaver)实现 State 持久化,
thread_id是隔离边界
关键模式:
ParentGraph (全局 State)
├── Subgraph A (局部 State,映射父 State 的部分 key)
├── Subgraph B (独立的局部 State)
└── Subgraph C (与 A 共享部分 State key)
2.2 CrewAI
层级组织方式:
- Crew → Agent → Task:Crew 是编排单元,包含多个 Agent 和 Task
- 共享内存:Crew 内的 Agent 共享一个 Memory 系统(支持 Short-term、Long-term、Entity Memory)
- 内置 SQLite 持久化:Crew 的执行状态和 Memory 可以持久化到 SQLite
共享上下文 vs 隔离:
- Crew 级别共享:同一 Crew 内的 Agent 默认共享上下文
- 跨 Crew 隔离:不同 Crew 的 Memory 默认隔离
- RAG 增强:支持向量检索来管理大规模上下文,避免全量加载
2.3 AutoGen
层级组织方式:
- Conversation → Agent Group → Agent:以对话为核心,Agent 组通过多轮对话协作
- 多对话模式:支持 two-agent chat、group chat、nested chat(层级嵌套)
- Context 传递:通过消息列表(chat history)传递上下文
共享上下文 vs 隔离:
- Group Chat 共享:同一 Group Chat 内的所有 Agent 共享完整的对话历史
- Nested Chat 隔离:嵌套对话有独立的消息历史,可通过闭包传递摘要结果
- 自定义 State:支持通过
ConversableAgent的context_variables传递结构化状态
2.4 OpenAI Swarm / Agents SDK
层级组织方式:
- Agent → Handoff → Agent:极简模型,Agent 之间通过 Handoff 传递控制权
- Context Variables:通过共享的字典传递上下文
- 无显式层级:没有 Project/Task 概念,是扁平的 Agent 网络
关键洞察:
OpenAI Swarm 的哲学是"最小抽象"——不引入层级概念,让开发者在代码层面自行组织。这适合简单场景,但在复杂工作流中缺乏结构化管理。
2.5 小结:AI Agent 编排系统的模式对比
| 系统 | 层级机制 | 共享上下文方式 | 隔离边界 | 持久化 |
|---|---|---|---|---|
| LangGraph | Graph/Subgraph 嵌套 | State key 映射 | thread_id | Checkpointer |
| CrewAI | Crew/Agent/Task | 共享 Memory | Crew 边界 | SQLite |
| AutoGen | Nested Chat | 对话历史 | Chat 边界 | 自定义 |
| OpenAI Swarm | 扁平 | Context Variables | 无显式边界 | 无 |
核心结论:AI Agent 编排系统的"共享 vs 隔离"权衡通常是"子任务隔离 + 结果摘要回传"。LangGraph 的 Subgraph 模式最接近我们的 Card/Epic 概念——每个 Subgraph 有自己的 State(类似黑板),执行完毕后通过 State 映射将关键结果传回父 Graph。
三、黑板系统(Blackboard Architecture)的上下文管理
3.1 经典黑板架构回顾
黑板架构的核心组成:
- Blackboard(黑板):共享的数据空间,存储问题求解的中间状态
- Knowledge Sources(知识源):独立的处理模块,观察黑板并响应变化
- Controller(控制器):决定哪个知识源在何时执行
3.2 大规模场景下的挑战:上下文膨胀
黑板系统在大规模场景下面临的核心问题:
- 数据增长:随着任务执行,黑板上的数据持续累积
- 相关性衰减:早期数据对当前决策的相关性逐渐降低
- 检索效率:大量数据导致查找变慢
- 上下文窗口限制:LLM 的上下文窗口有限,不能无限加载
3.3 业界解决方案
方案一:分层黑板(Hierarchical Blackboard)
将黑板分为多个层级,每层有不同的数据保留策略:
- L0 热层(Working Memory):当前活跃任务的数据,完整保留,常驻内存
- L1 温层(Context Buffer):近期完成的任务结果,保留摘要+关键指标
- L2 冷层(Archive):历史数据,仅保留元数据+索引,需要时通过向量检索召回
方案二:Context Folding(上下文折叠)
来自 ByteDance 2025 年的研究:
- Agent 执行子任务时进入独立的子轨迹(sub-trajectory)
- 子任务完成后,将中间步骤"折叠"为简洁的摘要
- 只保留最终结果和关键决策点,丢弃中间过程
这与我们的 Card 概念高度契合:Card 完成后,将整个黑板的详细数据折叠为摘要,只保留对上层有用的结论。
方案三:Hot/Cold Memory 分离
来自学术论文 "Codified Context"(2026)的实践:
- Hot Memory:始终加载的约定和规则(类似 system prompt),体积小但高频访问
- Cold Memory:按需加载的规范和文档,通过触发表(trigger table)自动路由
- 触发表:定义什么条件下加载什么冷数据,避免全量加载
方案四:摘要 + 向量检索
业界最常用的上下文管理策略:
- 历史对话嵌入向量存储
- 处理新查询时,通过语义检索召回相关历史
- 保留最近 5-7 轮完整上下文,更早的只保留摘要
- 合并相似度 > 0.95 的重复记忆
归档策略推荐
| 数据类型 | 热保留期 | 归档方式 | 召回方式 |
|---|---|---|---|
| 活跃任务数据 | 任务执行期间 | 完成后折叠 | 直接访问 |
| 任务结果摘要 | Card 生命周期内 | Card 完成后归档 | 向量检索 |
| 决策记录 | Project 生命周期内 | Project 结束后归档 | 元数据索引 |
| 执行日志 | 7 天 | 压缩存储 | 按需加载 |
四、Notion / Linear 的数据库模型
4.1 Notion 的数据模型
核心概念:
- Page:原子内容单元,可以是独立页面或数据库的一行
- Database(Data Source):结构化的 Page 集合,有自己的 schema(属性定义)
- Relation:数据库之间的关联关系
- Linked Database View:一个数据库在另一个位置的过滤视图
一个项目一个 DB vs 一个大 DB?
Notion 社区的争论和实践表明:
| 方案 | 优点 | 缺点 |
|---|---|---|
| 一个大 DB + 过滤 | 统一 schema,跨项目视图,维护简单 | 属性膨胀(不同类型任务属性不同),过滤复杂 |
| 多个 DB(按类型分) | 每个 DB 有专用 schema,更整洁 | 跨 DB 查询困难,rollup 受限(只支持一层) |
| 混合方案 | 任务用一个大 DB,项目/目标用独立 DB | 需要维护 Relation 关系 |
Notion 2025 的改进——Multiple Data Sources:
- 一个视图可以合并多个 Data Source
- 每个 Data Source 可以有独立的 schema
- 在视图层面进行统一展示和过滤
这启示我们:多类型实体可以用独立的 DB,通过关联关系连接,在视图层统一展示。
4.2 Linear 的数据模型
核心概念:
- Workspace → Team → Project → Issue
- 所有 Issue 存储在同一数据集中,通过
team_id和project_id过滤 - Project 可以跨 Team,是"倡议"级别的聚合
Linear 的设计哲学:
- 一个巨大的表:所有 Issue 共享同一 schema
- 自定义字段:通过 Custom Fields 扩展属性,而非不同的表
- Cycle/Project 作为视图:不是数据隔离,而是数据视图
4.3 数据库模型选型建议
| 场景 | 推荐模型 |
|---|---|
| 实体类型统一,属性差异小 | 单表 + 类型字段 + 过滤 |
| 实体类型差异大,属性结构不同 | 多表 + 关联关系 |
| 需要跨类型聚合查询 | 视图/物化视图层统一 |
五、最佳实践总结
5.1 什么粒度最适合做 DB 隔离边界?
核心原则:隔离边界应该在"需要独立生命周期管理"的粒度上。
| 层级 | 是否适合做 DB 隔离 | 理由 |
|---|---|---|
| Project | ❌ 不适合 | 数量少,生命周期长,需要跨项目查询和聚合 |
| Card/Epic | ✅ 最适合 | 数量适中,有明确的开始/结束,需要独立的上下文空间 |
| Task | ❌ 不适合 | 数量大,生命周期短,频繁创建/完成,独立 DB 管理成本过高 |
推荐方案:Card/Epic 级别的逻辑隔离(共享数据库实例 + Card 级别的数据分区/命名空间)
具体实现:
- 所有 Card 共享一个数据库实例
- 每个 Card 有独立的黑板命名空间(如
blackboard:{card_id}:*) - Card 完成后,其黑板数据归档(折叠为摘要),释放存储空间
- Project 级别维护一个聚合黑板,存储所有 Card 的摘要结果
5.2 黑板(共享上下文)的隔离策略
Project(全局聚合黑板)
├── Card A(独立黑板空间)
│ ├── Task A1 的产出
│ ├── Task A2 的产出
│ └── Card A 摘要(完成后回传给 Project)
├── Card B(独立黑板空间)
│ ├── Task B1 的产出
│ └── Card B 摘要
└── Project 聚合结果
关键规则:
- Card 间默认隔离:不同 Card 的黑板空间不互相访问
- 结果向上流动:Card 完成后,摘要结果写入 Project 级黑板
- 依赖显式声明:Card B 需要 Card A 的结果时,在定义中声明依赖,系统自动注入摘要
- 禁止向下传递全部数据:Task 只能看到自己 Card 的黑板,不会加载整个 Project 的数据
5.3 归档策略设计
阶段一:任务执行中
→ 黑板数据全量保留在热层
→ 每个 Task 完成后产出写入黑板
阶段二:Card 完成
→ 黑板数据"折叠":中间步骤摘要化
→ 保留:最终结果、关键决策、错误记录
→ 归档:原始日志、中间计算过程
→ 摘要写入 Project 级黑板
阶段三:Project 完成
→ 所有 Card 摘要聚合为 Project 报告
→ 全部黑板数据归档到冷存储
→ 保留可搜索的元数据索引
5.4 对 moziplus v2 的具体建议
-
数据库模型:采用"单实例 + Card 级命名空间"方案
- 所有任务共享一个数据库实例(SQLite 或 PostgreSQL)
- 每张表通过
card_id字段区分归属 - 黑板数据使用
blackboard_entries表,key 为{card_id}:{entry_key}
-
Task 类型:使用"单表 + 类型字段"方案
tasks表存储所有 Task,type字段区分类型- 不按 Task 类型分表,保持查询灵活性
-
Card 级隔离:
- 每个 Card 的黑板空间独立
- Card 间通过"依赖声明 + 摘要注入"传递上下文
- Card 完成时触发归档流程
-
上下文管理:
- 热层:活跃 Card 的完整黑板数据
- 温层:已完成 Card 的摘要数据(保留 7-30 天)
- 冷层:归档数据,通过向量检索按需召回
六、参考资料
- Jira Issue Hierarchy - Atlassian Community: https://community.atlassian.com/forums/Jira-questions/
- Jira Database Schema - Atlassian Developer: https://developer.atlassian.com/server/jira/platform/database-schema/
- Multi-Tenant Database Architecture Patterns - Bytebase: https://www.bytebase.com/blog/multi-tenant-database-architecture-patterns-explained/
- LangGraph Subgraphs Documentation: https://docs.langchain.com/oss/python/langgraph/use-subgraphs
- CrewAI Memory Documentation: https://docs.crewai.com/en/concepts/memory
- Context Folding (ByteDance, Oct 2025): https://medium.com/@najeebkan/context-management-for-ai-agents-d68716a37965
- Codified Context - Hot/Cold Memory Separation (2026): https://arxiv.org/html/2602.20478v1
- Azure AI Agent Design Patterns: https://learn.microsoft.com/en-us/azure/architecture/ai-ml/guide/ai-agent-design-patterns
- Notion Data Sources (2025): https://www.notionapps.com/blog/notion-data-sources-update-2025
- Agent Memory & State Management: https://www.techaheadcorp.com/blog/agent-memory-state/