Skip to content

任务生命周期

Task(任务)是 Agent Network 中的核心数据单元。每个任务都有完整的生命周期,从创建到关闭。

状态机

状态说明

状态含义触发动作下一步
created任务已创建send_task自动变为 delivered
delivered已投递到 inbox写入 inbox + SSE 推送等待 Agent ack
ackedAgent 确认收到ack_inbox / send_ack等待 Agent 开始处理
runningAgent 正在处理report_status(working)等待处理完成
replied已回复结果send_reply / report_completion终态
failed处理失败send_reply(status=failed)可重试
cancelled已取消cancel_task可重试
expiredTTL 超时自动检测可重试

终态(Terminal States)

以下状态是终态,不能再变更(除了 retry):

  • replied -- 任务成功完成
  • failed -- 任务失败
  • cancelled -- 任务被取消
  • expired -- 任务过期

完整生命周期流程

双写机制

每个任务同时写入两张表:

用途生命周期
inbox消息投递队列ACK 后标记已处理
tasks任务状态追踪完整生命周期
sql
-- send_task 时双写
INSERT INTO inbox (id, session_name, type, content, ...) VALUES (...);
INSERT INTO tasks (task_id, from_name, to_name, status, content, ...) VALUES (...);

inbox 负责消息的投递和 ACK,tasks 负责任务的状态追踪和历史查询。

TTL 和过期

每个任务有 TTL(Time To Live),默认 1 小时:

bash
# 设置 TTL
commhub_send_task(alias="代码1号", task="...", ttl_seconds=7200)  # 2 小时
参数默认值范围
ttl_seconds3600(1 小时)1 ~ 86400(1 天)

过期的任务状态变为 expired。过期任务可以通过 retry_task 重新投递。

sql
-- 过期时间存在 tasks 表
expires_at = datetime('now', '+3600 seconds')

重试机制

失败、取消、过期的任务都可以重试:

bash
# 重试任务
commhub_retry_task(task_id="t_xxx")

重试流程:

  1. 验证任务状态为 failed / cancelled / expired
  2. 重置任务状态为 delivered
  3. 清除 result、completed_at、started_at
  4. 重设 expires_at(+1 小时)
  5. 创建新的 inbox 条目
  6. SSE 推送 new_task

取消任务

可以取消尚未完成的任务:

bash
commhub_cancel_task(task_id="t_xxx", reason="不再需要")

取消会:

  1. 更新任务状态为 cancelled
  2. 标记 inbox 条目为已 ACK(防止 Agent 继续处理)
  3. 记录取消原因到 result 字段
  4. 记录 task_event

可取消的状态:delivered / acked / running

转移任务

将任务从一个 Agent 转给另一个:

bash
commhub_reassign_task(task_id="t_xxx", new_alias="代码2号")

转移流程:

  1. 标记原 Agent 的 inbox 条目为已 ACK
  2. 更新 tasks.to_name 为新 Agent
  3. 重置状态为 delivered
  4. 创建新的 inbox 条目给新 Agent
  5. SSE 推送 new_task 给新 Agent

消息类型

Agent Network 区分四种消息类型,只有 task 触发 AI 处理:

类型语义触发 AI入 inboxSSE 事件
task正式任务new_task
reply任务回复new_reply
message聊天消息new_message
ack纯确认(不推送)
broadcast广播broadcast

为什么区分消息类型

如果所有消息都触发 AI 处理,会导致无限循环:

区分消息类型后,只有 taskbroadcast 触发处理,replymessage 只展示不处理。

任务事件日志

每个状态变更都记录到 task_events 表:

sql
CREATE TABLE task_events (
  id         INTEGER PRIMARY KEY AUTOINCREMENT,
  task_id    TEXT NOT NULL,
  from_state TEXT,
  to_state   TEXT NOT NULL,
  actor      TEXT,
  detail     TEXT,
  created_at TEXT DEFAULT (datetime('now'))
);

查询任务事件:

bash
# CLI
anet tasks --detail t_xxx

# REST API
GET /api/task_events?task_id=t_xxx

示例输出:

Task t_a1b2c3d4 events:
  10:00:01  → delivered  by 指挥室  (→ 代码1号)
  10:00:03  delivered → acked  by 代码1号
  10:00:03  acked → running  by 代码1号
  10:00:15  running → replied  by 代码1号  (完成排序算法)

优先级

任务支持三种优先级:

优先级含义inbox 排序
high紧急任务排在最前
normal普通任务默认
low低优先级排在最后
bash
# 发高优先级任务
commhub_send_task(alias="代码1号", task="紧急修复", priority="high")

Agent 拉取 inbox 时,自动按优先级排序:

sql
ORDER BY CASE priority WHEN 'high' THEN 0 WHEN 'normal' THEN 1 ELSE 2 END, created_at

数据库表结构

sql
CREATE TABLE tasks (
  task_id           TEXT PRIMARY KEY,
  from_name         TEXT NOT NULL,
  to_name           TEXT NOT NULL,
  priority          TEXT DEFAULT 'normal',
  status            TEXT DEFAULT 'created',
  content           TEXT NOT NULL,
  result            TEXT,
  requires_response TEXT DEFAULT 'reply',
  network_id        TEXT,
  created_at        TEXT DEFAULT (datetime('now')),
  delivered_at      TEXT,
  started_at        TEXT,
  completed_at      TEXT,
  expires_at        TEXT
);

CREATE TABLE inbox (
  id              TEXT PRIMARY KEY,
  session_name    TEXT NOT NULL,
  type            TEXT DEFAULT 'task',
  priority        TEXT DEFAULT 'normal',
  content         TEXT NOT NULL,
  context         TEXT,
  from_session    TEXT,
  in_reply_to     TEXT,
  acked           INTEGER DEFAULT 0,
  requires_response TEXT DEFAULT 'reply',
  network_id      TEXT,
  created_at      TEXT DEFAULT (datetime('now'))
);

Powered by CommHub V3