Solon v4.0.2

harness - 子代理定义与任务委派

</> markdown
2026年6月14日 下午11:01:27

主代理(main)在处理复杂任务时,可以把子任务委派给“专项子代理”执行。子代理拥有独立的上下文与工具权限,互不污染。

1、内置子代理

solon-ai-harness 内置了几个常用子代理(开箱即用):

名称说明
general通用全能专家。其它子代理不匹配时优先选它
explore全域信息探索专家(本地文件 + 全网检索,无写权限)
plan规划与计划专家(制定逻辑路径与执行步骤,无写权限)
bashBash 命令执行专家(git、命令行操作,无写权限)
git-summaryGit 提交摘要生成专家(隐藏代理,内部使用)

2、子代理定义文件(Markdown)

子代理通过 Markdown 文件定义:YAML Front Matter 描述元数据,正文即系统提示词。文件放在 {harnessHome}/agents/ 或挂载的 AGENTS 目录下。

---
name: "code_reviewer"
description: "代码评审专家,定位风险并给出改进建议"
tools: ["read", "grep", "glob"]
model: "deepseek-v4-flash"
---

你是一位严谨的代码评审专家。

输出规范:
- 按“风险等级”分组列出问题。
- 每条问题须标注文件路径与行号。

元数据字段(Front Matter):

字段类型描述
nameString代理唯一标识
descriptionString职能描述(供主代理识别调度)
toolsList允许的工具(见《配置参考》工具权限表)
disallowedToolsList禁用的工具
modelString指定模型(不指定则用会话选中或主模型)
skillsList绑定的技能标识
mcpServersList绑定的 MCP 服务
memoryString记忆作用域(user / project / local)
permissionModeString权限模式
enabledbool是否启用(默认 true)
hiddenbool是否隐藏(不出现在可用代理列表)

注:tools 工具名大小写均可解析,lslist 等价。

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_nameresult_statusresult_content)回传给主代理。

5、动态生成子代理(generate)

当主代理拥有 generate 工具权限(且 subagentEnabled=true)时,模型可在运行中“即时创建”一个垂直领域的专家子代理。若 saveToFile=true,定义会持久化到 {workspace}/.soloncode/agents/{name}.md,后续可复用。