harness - 子代理定义与任务委派
2026年6月14日 下午11:01:27
主代理(main)在处理复杂任务时,可以把子任务委派给“专项子代理”执行。子代理拥有独立的上下文与工具权限,互不污染。
1、内置子代理
solon-ai-harness 内置了几个常用子代理(开箱即用):
| 名称 | 说明 |
|---|---|
general | 通用全能专家。其它子代理不匹配时优先选它 |
explore | 全域信息探索专家(本地文件 + 全网检索,无写权限) |
plan | 规划与计划专家(制定逻辑路径与执行步骤,无写权限) |
bash | Bash 命令执行专家(git、命令行操作,无写权限) |
git-summary | Git 提交摘要生成专家(隐藏代理,内部使用) |
2、子代理定义文件(Markdown)
子代理通过 Markdown 文件定义:YAML Front Matter 描述元数据,正文即系统提示词。文件放在 {harnessHome}/agents/ 或挂载的 AGENTS 目录下。
---
name: "code_reviewer"
description: "代码评审专家,定位风险并给出改进建议"
tools: ["read", "grep", "glob"]
model: "deepseek-v4-flash"
---
你是一位严谨的代码评审专家。
输出规范:
- 按“风险等级”分组列出问题。
- 每条问题须标注文件路径与行号。
元数据字段(Front Matter):
| 字段 | 类型 | 描述 |
|---|---|---|
name | String | 代理唯一标识 |
description | String | 职能描述(供主代理识别调度) |
tools | List | 允许的工具(见《配置参考》工具权限表) |
disallowedTools | List | 禁用的工具 |
model | String | 指定模型(不指定则用会话选中或主模型) |
skills | List | 绑定的技能标识 |
mcpServers | List | 绑定的 MCP 服务 |
memory | String | 记忆作用域(user / project / local) |
permissionMode | String | 权限模式 |
enabled | bool | 是否启用(默认 true) |
hidden | bool | 是否隐藏(不出现在可用代理列表) |
注:
tools工具名大小写均可解析,ls与list等价。
3、用代码动态定义子代理
无文件时,也可用代码构建子代理(详见 《harness - 进一步扩展定制参考》):
AgentDefinition definition = new AgentDefinition();
definition.setSystemPrompt("你是一位代码评审专家...");
definition.getMetadata().setName("code_reviewer");
definition.getMetadata().setDescription("代码评审专家");
definition.getMetadata().addTools(ToolPermission.TOOL_READ, ToolPermission.TOOL_GREP);
ReActAgent subagent = engine.createSubagent(definition).build();
subagent.prompt("评审 src 目录").session(session).call();
4、任务委派(task / multitask)
当主代理拥有 task 工具权限时,模型可自主把任务委派给子代理。马具内部由 TaskTalent 暴露两个能力:
task:委派单一任务给某个子代理(串行)。multitask:并行执行多个互不依赖的子任务(无资源竞争时优先用它以省时)。
每个子任务都是无状态的(上下文隔离),因此委派时必须在 prompt 中提供完成任务所需的全部背景。委派结果会以结构化片段(含 agent_name、result_status、result_content)回传给主代理。
5、动态生成子代理(generate)
当主代理拥有 generate 工具权限(且 subagentEnabled=true)时,模型可在运行中“即时创建”一个垂直领域的专家子代理。若 saveToFile=true,定义会持久化到 {workspace}/.soloncode/agents/{name}.md,后续可复用。