子代理是從現有代理執行中衍生的背景代理執行。 它們會在自己的工作階段中執行(Documentation Index
Fetch the complete documentation index at: https://docs2.openclaw.ai/llms.txt
Use this file to discover all available pages before exploring further.
agent:<agentId>:subagent:<uuid>),並在完成時將結果公告回請求者聊天頻道。每個子代理執行都會被追蹤為一個背景任務。
主要目標:
- 平行處理「研究 / 長時間任務 / 慢速工具」工作,而不阻塞主要執行。
- 預設保持子代理隔離(工作階段分離 + 選用沙盒)。
- 讓工具介面難以誤用:子代理預設不會取得工作階段工具。
- 支援可設定的巢狀深度,以配合編排器模式。
**成本注意事項:**每個子代理預設都有自己的脈絡與 token 使用量。對於繁重或重複性任務,請為子代理設定較便宜的模型,並讓主要代理使用品質較高的模型。透過
agents.defaults.subagents.model 或每個代理的覆寫設定進行設定。當子代理確實需要請求者目前的逐字稿時,代理可以在該次衍生中要求 context: "fork"。繫結執行緒的子代理工作階段預設為 context: "fork",因為它們會將目前對話分支到後續執行緒中。斜線命令
使用/subagents 檢查或控制目前工作階段的子代理執行:
/steer <message> 引導目前請求者工作階段的作用中執行。當目標是子執行時,使用 /subagents steer <id|#> <message>。
/subagents info 會顯示執行中繼資料(狀態、時間戳記、工作階段 ID、逐字稿路徑、清理)。使用 sessions_history 取得有界且經安全篩選的回想檢視;當你需要原始完整逐字稿時,請檢查磁碟上的逐字稿路徑。
執行緒繫結控制項
這些命令可用於支援持久執行緒繫結的頻道。 請參閱下方的支援執行緒的頻道。衍生行為
/subagents spawn 會以使用者命令(不是內部轉送)啟動背景子代理,並在執行完成時將一則最終完成更新傳送回請求者聊天。
非阻塞、推送式完成
非阻塞、推送式完成
- 衍生命令是非阻塞的;它會立即傳回執行 ID。
- 完成時,子代理會將摘要/結果訊息公告回請求者聊天頻道。
- 需要子執行結果的代理回合,應在衍生必要工作後呼叫
sessions_yield。這會結束目前回合,並讓完成事件以下一則模型可見訊息的形式送達。 - 完成採用推送式。衍生後,請不要為了等待完成而在迴圈中輪詢
/subagents list、sessions_list或sessions_history;只在除錯或介入時按需檢查狀態。 - 子輸出是給請求者代理彙整的報告/證據。它不是使用者撰寫的指示文字,且不能覆寫系統、開發者或使用者政策。
- 完成時,OpenClaw 會盡最大努力關閉該子代理工作階段開啟並被追蹤的瀏覽器分頁/程序,然後公告清理流程才會繼續。
手動衍生交付韌性
手動衍生交付韌性
- OpenClaw 會透過具有穩定冪等鍵的
agent回合,將完成結果交回請求者工作階段。 - 如果請求者執行仍在作用中,OpenClaw 會先嘗試喚醒/引導該執行,而不是啟動第二條可見回覆路徑。
- 如果請求者代理完成交接失敗或沒有產生可見輸出,OpenClaw 會將交付視為失敗,並退回到佇列路由/重試。它不會將子結果直接原始傳送到外部聊天。
- 如果無法使用直接交接,則會退回到佇列路由。
- 如果佇列路由仍不可用,公告會以短暫指數退避重試,之後才最終放棄。
- 完成交付會保留已解析的請求者路由:可用時,繫結執行緒或繫結對話的完成路由會優先;如果完成來源只提供頻道,OpenClaw 會從請求者工作階段已解析的路由(
lastChannel/lastTo/lastAccountId)填入缺少的目標/帳號,因此直接交付仍可運作。
完成交接中繼資料
完成交接中繼資料
交給請求者工作階段的完成交接是執行階段產生的內部脈絡(不是使用者撰寫文字),並包含:
Result— 最新可見的assistant回覆文字,否則為經清理的最新工具/toolResult 文字。終止且失敗的執行不會重用擷取到的回覆文字。Status—completed successfully/failed/timed out/unknown。- 精簡的執行階段/token 統計資料。
- 一則交付指示,要求請求者代理以一般助理語氣重寫(不要轉送原始內部中繼資料)。
模式與 ACP 執行階段
模式與 ACP 執行階段
--model與--thinking會覆寫該特定執行的預設值。- 完成後使用
info/log檢查詳細資料與輸出。 /subagents spawn是一次性模式(mode: "run")。若要使用持久的繫結執行緒工作階段,請搭配thread: true和mode: "session"使用sessions_spawn。- 對於 ACP harness 工作階段(Claude Code、Gemini CLI、OpenCode,或明確的 Codex ACP/acpx),當工具宣告該執行階段時,請搭配
runtime: "acp"使用sessions_spawn。除錯完成結果或代理對代理迴圈時,請參閱 ACP 交付模型。啟用codexplugin 時,除非使用者明確要求 ACP/acpx,否則 Codex 聊天/執行緒控制應優先使用/codex ...而非 ACP。 - OpenClaw 會隱藏
runtime: "acp",直到 ACP 已啟用、請求者未被沙盒化,且已載入例如acpx的後端 plugin。runtime: "acp"需要外部 ACP harness ID,或是具有runtime.type="acp"的agents.list[]項目;對於來自agents_list的一般 OpenClaw 設定代理,請使用預設子代理執行階段。
脈絡模式
原生子代理會以隔離狀態啟動,除非呼叫者明確要求分支目前逐字稿。| 模式 | 使用時機 | 行為 |
|---|---|---|
isolated | 新研究、獨立實作、慢速工具工作,或任何可在任務文字中簡述的事項 | 建立乾淨的子逐字稿。這是預設值,並能降低 token 使用量。 |
fork | 依賴目前對話、先前工具結果,或請求者逐字稿中已有細緻指示的工作 | 在子代理啟動前,將請求者逐字稿分支到子工作階段中。 |
fork。它是用於對脈絡敏感的委派,而不是取代清楚撰寫任務提示。
工具:sessions_spawn
在全域 subagent 通道上以 deliver: false 啟動子代理執行,然後執行公告步驟,並將公告回覆張貼到請求者聊天頻道。
可用性取決於呼叫者的有效工具政策。coding 與 full 設定檔預設會公開 sessions_spawn。messaging 設定檔不會;對於應委派工作的代理,請加入 tools.alsoAllow: ["sessions_spawn", "sessions_yield", "subagents"],或使用 tools.profile: "coding"。頻道/群組、提供者、沙盒,以及每個代理的允許/拒絕政策,仍可在設定檔階段之後移除該工具。請從同一工作階段使用 /tools 確認有效工具清單。
預設值:
- **模型:**除非你設定
agents.defaults.subagents.model(或每個代理的agents.list[].subagents.model),否則會繼承呼叫者;明確的sessions_spawn.model仍會優先。 - **Thinking:**除非你設定
agents.defaults.subagents.thinking(或每個代理的agents.list[].subagents.thinking),否則會繼承呼叫者;明確的sessions_spawn.thinking仍會優先。 - **執行逾時:**如果省略
sessions_spawn.runTimeoutSeconds,OpenClaw 會在有設定時使用agents.defaults.subagents.runTimeoutSeconds;否則退回到0(無逾時)。
委派提示模式
agents.defaults.subagents.delegationMode 只控制提示指引;它不會變更工具政策或強制委派。
suggest(預設):保留標準提示提醒,以便在較大或較慢的工作中使用子代理。prefer:告訴主要代理保持回應性,並透過sessions_spawn委派任何比直接回覆更複雜的工作。
agents.list[].subagents.delegationMode。
工具參數
子代理的任務描述。
選用的穩定控制代稱,用於稍後的
subagents 目標指定。必須符合 [a-z][a-z0-9_]{0,63},且不能是 last 或 all 等保留目標。當協調者在產生多個子項後,可能需要引導、終止或識別特定子項時,請優先使用它。選用的人類可讀標籤。
在
subagents.allowAgents 允許時,於另一個代理 id 下產生。acp 僅適用於外部 ACP 控制框架(claude、droid、gemini、opencode,或明確要求的 Codex ACP/acpx),以及 runtime.type 為 acp 的 agents.list[] 項目。僅限 ACP。當
runtime: "acp" 時恢復現有 ACP 控制框架工作階段;原生子代理產生會忽略此項。僅限 ACP。當
runtime: "acp" 時,將 ACP 執行輸出串流到父工作階段;原生子代理產生時請省略。覆寫子代理模型。無效值會被略過,子代理會在預設模型上執行,並在工具結果中顯示警告。
覆寫子代理執行的思考層級。
設定時預設為
agents.defaults.subagents.runTimeoutSeconds,否則為 0。設定後,子代理執行會在 N 秒後中止。為
true 時,會為此子代理工作階段要求頻道討論串繫結。如果
thread: true 且省略 mode,預設會變成 session。mode: "session" 需要 thread: true。"delete" 會在宣告後立即封存(仍會透過重新命名保留逐字稿)。require 會拒絕產生,除非目標子執行階段已沙箱化。fork 會將請求者目前的逐字稿分支到子工作階段。僅限原生子代理。繫結討論串的產生預設為 fork;非討論串產生預設為 isolated。任務名稱與目標指定
taskName 是面向模型的協調控制代稱,不是工作階段金鑰。
當協調者稍後可能需要引導或終止該子項時,請將它用於穩定的子項名稱,例如 review_subagents、
linux_validation 或 docs_update。
目標解析接受完全相符的 taskName,以及不含歧義的前綴。
比對範圍限於編號 /subagents 目標所使用的相同作用中/近期目標視窗,因此過期的已完成子項不會讓重複使用的控制代稱產生歧義。如果兩個作用中或近期子項共用相同
taskName,目標就有歧義;請改用清單索引、工作階段金鑰或執行 id。
保留目標 last 和 all 不是有效的 taskName 值,因為它們已經具有控制意義。
工具:sessions_yield
結束目前模型回合並等待執行階段事件,主要是子代理完成事件,作為下一則訊息到達。當請求者必須等這些完成事件到達後才能產生最終答案時,請在產生必要子項工作後使用它。
sessions_yield 是等待原語。不要為了偵測子項完成,就用輪詢 subagents、sessions_list、sessions_history、shell
sleep 或程序輪詢迴圈取代它。
只有在工作階段的有效工具清單包含 sessions_yield 時才使用它。某些最小或自訂工具設定檔可能會公開 sessions_spawn 和
subagents,但不公開 sessions_yield;在這種情況下,不要為了等待完成而自創輪詢迴圈。
當存在作用中的子項時,OpenClaw 會將精簡、由執行階段產生的
Active Subagents 提示區塊注入一般回合,讓請求者不需輪詢即可看到目前子工作階段、執行 id、狀態、標籤、任務和
taskName 別名。該區塊中的任務和標籤欄位會以資料形式加上引號,而不是作為指令,因為它們可能來自使用者/模型提供的產生引數。
工具:subagents
列出、引導或終止請求者工作階段所擁有的已產生子代理執行。它的範圍限於目前請求者;子項只能看到/控制自己所控制的子項。
使用 subagents 進行隨選狀態查詢、偵錯、引導或終止。
使用 sessions_yield 等待完成事件。
繫結討論串的工作階段
當頻道啟用討論串繫結時,子代理可以持續繫結到討論串,讓該討論串中的後續使用者訊息繼續路由到相同的子代理工作階段。支援討論串的頻道
Discord 目前是唯一支援的頻道。它支援持久化的繫結討論串子代理工作階段(使用sessions_spawn 搭配 thread: true)、手動討論串控制(/focus、/unfocus、/agents、
/session idle、/session max-age),以及配接器金鑰
channels.discord.threadBindings.enabled、
channels.discord.threadBindings.idleHours、
channels.discord.threadBindings.maxAgeHours 和
channels.discord.threadBindings.spawnSessions。
快速流程
手動控制
| 命令 | 效果 |
|---|---|
/focus <target> | 將目前討論串(或建立一個)繫結到子代理/工作階段目標 |
/unfocus | 移除目前已繫結討論串的繫結 |
/agents | 列出作用中執行與繫結狀態(thread:<id> 或 unbound) |
/session idle | 檢查/更新閒置自動取消聚焦(僅限已聚焦的繫結討論串) |
/session max-age | 檢查/更新硬性上限(僅限已聚焦的繫結討論串) |
設定開關
- 全域預設值:
session.threadBindings.enabled、session.threadBindings.idleHours、session.threadBindings.maxAgeHours。 - 頻道覆寫與產生自動繫結金鑰為配接器專屬。請參閱上方的支援討論串的頻道。
允許清單
可透過明確
agentId 指定為目標的代理 id 清單(["*"] 允許任何代理)。預設:僅請求者代理。如果你設定了清單,而且仍希望請求者能使用 agentId 產生自身,請在清單中包含請求者 id。當請求者代理未設定自己的
subagents.allowAgents 時使用的預設目標代理允許清單。封鎖省略
agentId 的 sessions_spawn 呼叫(強制明確選擇設定檔)。每代理覆寫:agents.list[].subagents.requireAgentId。Gateway
agent 宣告傳遞嘗試的每次呼叫逾時。值為正整數毫秒,並會限制在平台安全計時器最大值內。暫時性重試可能讓總宣告等待時間比單一設定逾時更長。sessions_spawn 會拒絕會以非沙箱方式執行的目標。
探索
使用agents_list 查看目前允許用於 sessions_spawn 的代理 id。回應包含每個列出代理的有效模型和嵌入式執行階段中繼資料,讓呼叫者可以區分 PI、Codex 應用程式伺服器,以及其他已設定的原生執行階段。
自動封存
- 子代理工作階段會在
agents.defaults.subagents.archiveAfterMinutes後自動封存(預設60)。 - 封存使用
sessions.delete,並將逐字稿重新命名為*.deleted.<timestamp>(同一資料夾)。 cleanup: "delete"會在宣告後立即封存(仍會透過重新命名保留逐字稿)。- 自動封存為盡力而為;如果 gateway 重新啟動,待處理的計時器會遺失。
runTimeoutSeconds不會自動封存;它只會停止執行。工作階段會保留到自動封存為止。- 自動封存同等適用於深度 1 和深度 2 工作階段。
- 瀏覽器清理與封存清理是分開的:追蹤的瀏覽器分頁/程序會在執行完成時盡力關閉,即使逐字稿/工作階段記錄被保留也是如此。
巢狀子代理
預設情況下,子代理不能產生自己的子代理 (maxSpawnDepth: 1)。設定 maxSpawnDepth: 2 可啟用一層巢狀
,也就是協調者模式:主代理 → 協調者子代理 →
工作者子子代理。
深度層級
| 深度 | 工作階段金鑰形狀 | 角色 | 可以產生? |
|---|---|---|---|
| 0 | agent:<id>:main | 主代理 | 一律可以 |
| 1 | agent:<id>:subagent:<uuid> | 子代理(允許深度 2 時為協調者) | 僅當 maxSpawnDepth >= 2 |
| 2 | agent:<id>:subagent:<uuid>:subagent:<uuid> | 子子代理(葉節點工作者) | 永不 |
宣告鏈
結果會沿鏈向上流動:- 深度 2 工作者完成 → 宣告給其父項(深度 1 協調者)。
- 深度 1 協調者接收宣告、合成結果、完成 → 宣告給主代理。
- 主代理接收宣告並傳遞給使用者。
**操作指引:**只啟動一次子工作,並等待完成事件,而不是圍繞
sessions_list、sessions_history、/subagents list 或 exec sleep 命令建立輪詢迴圈。sessions_list 和 /subagents list 會讓子工作階段關係專注於執行中的工作:執行中的子項會保持附加,已結束的子項會在短暫的最近視窗中保持可見,而過時且僅存在於儲存區的子項連結會在其新鮮度視窗後被忽略。這可防止舊的 spawnedBy / parentSessionKey 中繼資料在重新啟動後復活幽靈子項。如果子項完成事件在你已送出最終回答後才抵達,正確的後續回應是精確的靜默權杖 NO_REPLY / no_reply。依深度的工具策略
- 角色與控制範圍會在產生時寫入工作階段中繼資料。這可避免扁平化或還原的工作階段金鑰意外重新取得協調器權限。
- **深度 1(協調器,當
maxSpawnDepth >= 2時):**取得sessions_spawn、subagents、sessions_list、sessions_history,以便管理其子項。其他工作階段/系統工具仍會被拒絕。 - **深度 1(葉節點,當
maxSpawnDepth == 1時):**沒有工作階段工具(目前的預設行為)。 - **深度 2(葉節點工作器):**沒有工作階段工具;在深度 2 時一律拒絕
sessions_spawn。無法再產生更多子項。
每個代理的產生限制
每個代理工作階段(任何深度)同一時間最多可有maxChildrenPerAgent(預設 5)個作用中子項。這可防止單一協調器造成失控的扇出。
串聯停止
停止深度 1 協調器會自動停止其所有深度 2 子項:- 主聊天中的
/stop會停止所有深度 1 代理,並串聯停止其深度 2 子項。 /subagents kill <id>會停止特定子代理,並串聯停止其子項。/subagents kill all會停止請求者的所有子代理,並進行串聯停止。
驗證
子代理驗證會依 代理 ID 解析,而不是依工作階段類型:- 子代理工作階段金鑰為
agent:<agentId>:subagent:<uuid>。 - 驗證儲存區會從該代理的
agentDir載入。 - 主代理的驗證設定檔會合併作為備援;發生衝突時,代理設定檔會覆寫主設定檔。
通告
子代理會透過通告步驟回報:- 通告步驟在子代理工作階段內執行(不是請求者工作階段)。
- 如果子代理精確回覆
ANNOUNCE_SKIP,就不會發布任何內容。 - 如果最新的助理文字是精確的靜默權杖
NO_REPLY/no_reply,即使先前曾有可見進度,也會抑制通告輸出。
- 頂層請求者工作階段會使用帶有外部傳遞的後續
agent呼叫(deliver=true)。 - 巢狀請求者子代理工作階段會接收內部後續注入(
deliver=false),讓協調器可在工作階段內合成子項結果。 - 如果巢狀請求者子代理工作階段已不存在,OpenClaw 會在可用時退回使用該工作階段的請求者。
通告內容
通告內容會正規化為穩定的內部事件區塊:| 欄位 | 來源 |
|---|---|
| 來源 | subagent 或 cron |
| 工作階段 ID | 子工作階段金鑰/ID |
| 類型 | 通告類型 + 任務標籤 |
| 狀態 | 從執行階段結果衍生(success、error、timeout 或 unknown);不是從模型文字推斷 |
| 結果內容 | 最新可見的助理文字,否則為已清理的最新工具/toolResult 文字 |
| 後續 | 描述何時回覆與何時保持靜默的指示 |
統計列
通告承載內容會在結尾包含統計列(即使已換行包覆):- 執行時間(例如
runtime 5m12s)。 - 權杖用量(輸入/輸出/總計)。
- 設定模型定價時的預估成本(
models.providers.*.models[].cost)。 sessionKey、sessionId與轉錄路徑,讓主代理可透過sessions_history擷取歷史,或檢查磁碟上的檔案。
為什麼偏好 sessions_history
sessions_history 是較安全的協調路徑:
- 助理回憶會先正規化:移除 thinking 標籤;移除
<relevant-memories>/<relevant_memories>鷹架;移除純文字工具呼叫 XML 承載區塊(<tool_call>、<function_call>、<tool_calls>、<function_calls>),包括從未乾淨關閉的截斷承載;移除降級的工具呼叫/結果鷹架與歷史內容標記;移除洩漏的模型控制權杖(<|assistant|>、其他 ASCII<|...|>、全形<|...|>);移除格式錯誤的 MiniMax 工具呼叫 XML。 - 類似認證/權杖的文字會被遮蔽。
- 長區塊可被截斷。
- 非常大的歷史可丟棄較舊的列,或以
[sessions_history omitted: message too large]取代過大的列。 - 當你需要完整逐位元組一致的轉錄時,原始磁碟轉錄檢查是備援方式。
工具策略
子代理會先使用與父代理或目標代理相同的設定檔與工具策略管線。之後,OpenClaw 會套用子代理限制層。 若沒有具限制性的tools.profile,子代理會取得除工作階段工具與系統工具以外的所有工具:
sessions_listsessions_historysessions_sendsessions_spawn
sessions_history 在這裡仍是有界且已清理的回憶檢視;它不是原始轉錄傾印。
當 maxSpawnDepth >= 2 時,深度 1 協調器子代理還會收到 sessions_spawn、subagents、sessions_list 和 sessions_history,以便管理其子項。
透過設定覆寫
tools.subagents.tools.allow 是最終的僅允許篩選器。它可以縮小已解析的工具集合,但無法加回被 tools.profile 移除的工具。例如,tools.profile: "coding" 包含 web_search/web_fetch,但不包含 browser 工具。若要讓 coding 設定檔的子代理使用瀏覽器自動化,請在設定檔階段加入 browser:
agents.list[].tools.alsoAllow: ["browser"]。
並行
子代理使用專用的進程內佇列通道:- 通道名稱:
subagent - 並行度:
agents.defaults.subagents.maxConcurrent(預設8)
存活性與復原
OpenClaw 不會將缺少endedAt 視為子代理仍存活的永久證明。早於過時執行視窗且尚未結束的執行,將不再於 /subagents list、狀態摘要、後代完成閘控與每工作階段並行檢查中計為作用中/待處理。
Gateway 重新啟動後,過時且未結束的已還原執行會被修剪,除非其子工作階段標記為 abortedLastRun: true。這些因重新啟動而中止的子工作階段仍可透過子代理孤兒復原流程復原;該流程會在清除中止標記前送出合成的恢復訊息。
自動重新啟動復原會依每個子工作階段設限。如果同一個子代理子項在快速重新卡住視窗內反覆被接受進行孤兒復原,OpenClaw 會在該工作階段上保存復原墓碑,並在之後重新啟動時停止自動恢復它。執行 openclaw tasks maintenance --apply 來協調任務記錄,或執行 openclaw doctor --fix 來清除墓碑工作階段上的過時中止復原旗標。
如果子代理產生失敗並出現 Gateway
PAIRING_REQUIRED / scope-upgrade,請先檢查 RPC 呼叫者,再編輯配對狀態。內部 sessions_spawn 協調應以 client.id: "gateway-client" 搭配 client.mode: "backend",透過直接 loopback 共享權杖/密碼驗證連線;該路徑不依賴 CLI 的已配對裝置範圍基準線。遠端呼叫者、明確的 deviceIdentity、明確的裝置權杖路徑,以及 browser/Node 用戶端,仍需要一般裝置核准才能進行範圍升級。停止
- 在請求者聊天中送出
/stop會中止請求者工作階段,並停止從中產生的任何作用中子代理執行,且串聯至巢狀子項。 /subagents kill <id>會停止特定子代理,並串聯停止其子項。
限制
- 子代理通告是盡力而為。如果 Gateway 重新啟動,待處理的「回傳通告」工作會遺失。
- 子代理仍共享相同的 Gateway 行程資源;請將
maxConcurrent視為安全閥。 sessions_spawn一律為非阻塞:它會立即傳回{ status: "accepted", runId, childSessionKey }。- 子代理內容只會注入
AGENTS.md、TOOLS.md、SOUL.md、IDENTITY.md和USER.md(不包含MEMORY.md、HEARTBEAT.md或BOOTSTRAP.md)。 - 最大巢狀深度為 5(
maxSpawnDepth範圍:1–5)。大多數使用情境建議使用深度 2。 maxChildrenPerAgent會限制每個工作階段的作用中子項數量(預設5,範圍1–20)。