【Claude Code】长时间运行 agents 的有效控制框架

作者:是魔丸啊日期:2025/12/6

转载

Harness原意是马具,从马具控制马匹,引申为一个控制和管理框架,用于封装、引导和监督AI代理的行为。后文为了保持原意,作为专有名词不翻译了。

文中提到的initializer agent / coding agent,并不是claude code已经内置的机制,而是一个最佳实践,需要自行配置。如果想要prompt,可以去这里寻找:github.com/anthropics/…

随着 AI agents 变得更加强大,开发者越来越多地要求它们承担需要跨越数小时甚至数天工作的复杂任务。然而,让 agents 在多个上下文窗口中保持一致的进展仍然是一个悬而未决的问题。

长时间运行 agents 的核心挑战在于,它们必须在离散的会话中工作,而每个新会话开始时对之前发生的事情没有任何记忆。想象一个由轮班工程师组成的软件项目,每个新来的工程师对上一个班次发生的事情毫无记忆。由于上下文窗口有限,且大多数复杂项目无法在单个窗口内完成,agents 需要一种方法来弥合编码会话之间的差距。

我们开发了一个双重解决方案,使 Claude Agent SDK 能够在许多上下文窗口中有效工作:一个initializer agent(初始化 agent)在第一次运行时设置环境,以及一个coding agent(编码 agent)在每个会话中取得增量进展,同时为下一个会话留下清晰的工件。您可以在附带的快速入门指南中找到代码示例。

长时间运行 agent 的问题

Claude Agent SDK 是一个强大、通用的 agent harness,不仅擅长编码,还擅长其他需要模型使用工具来收集上下文、规划和执行的任务。它具备上下文管理功能,如压缩(compaction),这使得 agent 能够在不耗尽上下文窗口的情况下继续工作。理论上,在这种设置下,agent 应该能够持续进行有用的工作,时间可长达任意程度。

然而,仅靠压缩是不够的。开箱即用的情况下,即使是像 Opus 4.5 这样的前沿编码模型,在 Claude Agent SDK 上跨多个上下文窗口循环运行时,如果只给它一个高级提示,如"构建一个 claude.ai 的克隆版",也无法构建出生产质量的网络应用程序。

Claude 的失败表现为两种模式。首先,agent 倾向于一次性做太多事情——本质上是试图一举完成整个应用程序。这往往导致模型在实现过程中耗尽上下文,留给下一个会话一个功能半实现且未记录的混乱状态。然后,agent 必须猜测发生了什么,并花费大量时间试图让基本应用程序重新运行。即使有压缩功能,这种情况依然会发生,因为压缩并不总是能向下一个 agent 传递完全清晰的指令。

第二种失败模式通常在项目后期出现。在已经构建了一些功能后,后续的 agent 实例会环顾四周,看到已经取得了进展,就草率地宣布任务完成。

这把问题分解为两个部分。首先,我们需要设置一个初始环境,为给定提示所需的所有功能奠定基础,这为 agent 逐步、逐个功能地工作做好了准备。其次,我们应该提示每个 agent 朝着其目标取得增量进展,同时在会话结束时将环境保持在干净状态。所谓"干净状态",我们指的是适合合并到主分支的代码:没有重大错误,代码有序且文档完善,总体上,开发者可以轻松开始新功能的工作,而无需先清理无关的遗留问题。

在内部实验时,我们使用两部分解决方案解决了这些问题:

  1. Initializer agent:第一个 agent 会话使用专门的提示,要求模型设置初始环境:一个 init.sh 脚本、一个记录 agents 所做工作的 claude-progress.txt 文件,以及一个显示添加了什么文件的初始 git 提交。
  2. Coding agent:每个后续会话要求模型取得增量进展,然后留下结构化更新。

这里的关键洞察在于找到一种方法,让 agents 在从头开始的上下文窗口中能够快速理解工作状态,这通过 claude-progress.txt 文件与 git 历史记录配合实现。这些实践的灵感来源于了解优秀软件工程师的日常工作习惯。

环境管理

在更新的 Claude 4 提示指南中,我们分享了一些多上下文窗口工作流程的最佳实践,包括一个使用"对第一个上下文窗口使用不同提示"的 harness 结构。这个"不同提示"要求 initializer agent 设置环境,包含未来 coding agents 有效工作所需的所有必要上下文。在这里,我们深入探讨这种环境的一些关键组件。

功能列表

为了解决 agent 试图一次性完成应用程序或过早认为项目完成的问题,我们提示 initializer agent 编写一个全面的功能需求文件,扩展用户的初始提示。在 claude.ai 克隆示例中,这意味着超过 200 个功能,如"用户可以打开新聊天、输入查询、按回车键并看到 AI 响应"。这些功能最初都标记为"失败",以便后续的 coding agents 能够清楚地了解完整功能应该是什么样子。

1{
2    "category": "functional",
3    "description": "New chat button creates a fresh conversation",
4    "steps": [
5      "Navigate to main interface",
6      "Click the 'New Chat' button",
7      "Verify a new conversation is created",
8      "Check that chat area shows welcome state",
9      "Verify conversation appears in sidebar"
10    ],
11    "passes": false
12  }
13

我们提示 coding agents 仅通过更改 passes 字段的状态来编辑此文件,并使用措辞强烈的指令,如"删除或编辑测试是不可接受的,因为这可能导致功能缺失或错误"。经过一些实验,我们选择使用 JSON 格式,因为与 Markdown 文件相比,模型不太可能不当更改或覆盖 JSON 文件。

增量进展

基于这种初始环境脚手架,coding agent 的后续迭代被要求一次只处理一个功能。这种增量方法被证明是解决 agent 倾向于一次性做太多问题的关键。

一旦开始增量工作,模型在进行代码更改后仍需要将环境保持在干净状态,这一点仍然至关重要。在我们的实验中,我们发现引发这种行为的最有效方式是要求模型将其进展以描述性的提交消息提交到 git,并在进度文件中写下工作摘要。这使得模型能够使用 git 来恢复错误的代码更改并恢复代码库的工作状态。

这些方法还提高了效率,因为它们消除了 agent 猜测发生了什么并花费时间试图让基本应用程序重新运行的需要。

测试

我们观察到的最后一个主要失败模式是 Claude 在没有适当测试的情况下就将功能标记为完成的倾向。在没有明确提示的情况下,Claude 倾向于进行代码更改,甚至通过单元测试或针对开发服务器的 curl 命令进行测试,但未能识别功能端到端不工作的问题。

在构建网络应用程序的情况下,一旦明确提示使用浏览器自动化工具并像人类用户一样进行所有测试,Claude 在端到端验证功能方面表现良好。

Claude 通过 Puppeteer MCP 服务器测试 claude.ai 克隆时拍摄的截图。

为 Claude 提供这些类型的测试工具显著提高了性能,因为 agent 能够识别并修复从代码本身看不出的错误。

仍然存在一些问题,比如 Claude 视觉能力和浏览器自动化工具的局限性,使其难以识别每种类型的错误。例如,Claude 无法通过 Puppeteer MCP 看到浏览器原生的警告模态框,依赖这些模态框的功能因此往往存在更多错误。

快速了解情况

有了以上所有设置,每个 coding agent 都被提示运行一系列步骤来了解情况,有些步骤相当基本但仍然有帮助:

  1. 运行 pwd 查看您正在工作的目录。您只能编辑此目录中的文件。
  2. 阅读 git 日志和进度文件,以了解最近的工作进展。
  3. 阅读功能列表文件,选择尚未完成的最高优先级功能来处理。

这种方法为 Claude 在每个会话中节省了一些令牌,因为它不必重新摸索如何测试代码。还有助于要求 initializer agent 编写一个可以运行开发服务器的 init.sh 脚本,然后在实现新功能之前运行基本的端到端测试。

在 claude.ai 克隆的情况下,这意味着 agent 总是启动本地开发服务器并使用 Puppeteer MCP 开始新聊天、发送消息并接收响应。这确保了 Claude 能够快速识别应用程序是否处于损坏状态,并立即修复任何现有错误。如果 agent 反而开始实现新功能,很可能会使问题恶化。

考虑到所有这些,典型的会话以以下助手消息开始:

1[Assistant] 我将首先了解情况并理解项目的当前状态。
2[Tool Use] <bash - pwd>
3[Tool Use] <read - claude-progress.txt>
4[Tool Use] <read - feature_list.json>
5[Assistant] 让我检查 git 日志以查看最近的工作。
6[Tool Use] <bash - git log --oneline -20>
7[Assistant] 现在让我检查是否有 init.sh 脚本来重启服务器。
8<Starts the development server>
9[Assistant] 太好了!现在让我导航到应用程序并验证一些基本功能是否仍在工作。
10<Tests basic functionality>
11[Assistant] 基于我的验证测试,我可以看到基本功能运行良好。核心聊天功能、主题切换、会话加载和错误处理都正常工作。现在让我更全面地查看 tests.json 文件,以了解接下来需要实现什么。
12<Starts work on a new feature>
13

Agent 失败模式和解决方案

问题Initializer Agent 行为Coding Agent 行为
Claude 过早宣布整个项目胜利。设置功能列表文件:基于输入规范,建立一个包含端到端功能描述列表的结构化 JSON 文件。在会话开始时阅读功能列表文件。选择单个功能开始处理。
Claude 将环境留在有错误或未记录进展的状态。编写一个初始 git 仓库和进度笔记文件。在会话开始时阅读进度笔记文件和 git 提交日志,并在开发服务器上运行基本测试以捕获任何未记录的错误。在会话结束时编写 git 提交和进度更新。
Claude 过早将功能标记为完成。设置功能列表文件。自我验证所有功能。只有在仔细测试后才将功能标记为"通过"。
Claude 必须花时间弄清楚如何运行应用程序。编写一个可以运行开发服务器的 init.sh 脚本。在会话开始时阅读 init.sh。

总结了长时间运行 AI agents 中四种常见失败模式和解决方案。

未来工作

这项研究展示了在长时间运行 agent harness 中一套可能的解决方案,使模型能够在许多上下文窗口中取得增量进展。然而,仍然存在未解决的问题。

最值得注意的是,目前仍不清楚单一的通用 coding agent 是否在所有上下文中表现最佳,或者是否可以通过多 agent 架构获得更好的性能。看起来合理的想法是,专门的 agents,如测试 agent、质量保证 agent 或代码清理 agent,可以在软件开发生命周期的子任务上做得更好。

此外,这个演示针对全栈网络应用程序开发进行了优化。未来的一个方向是将这些发现推广到其他领域。这些教训中的一些或全部很可能可以应用于,例如,科学研究或金融建模中需要的长时间运行 agent 任务类型。

致谢

由 Justin Young 撰写。特别感谢 David Hershey、Prithvi Rajasakeran、Jeremy Hadfield、Naia Bouscal、Michael Tingley、Jesse Mu、Jake Eaton、Marius Buleandara、Maggie Vo、Pedram Navid、Nadine Yasser 和 Alex Notov 的贡献。

这项工作反映了 Anthropic 多个团队的集体努力,这些团队使 Claude 能够安全地进行长时程自主软件工程,特别是代码 RL 和 Claude Code 团队。欢迎有兴趣做出贡献的候选人申请 anthropic.com/careers。

脚注

  1. 我们在此上下文中称它们为独立的 agents,仅仅是因为它们有不同的初始用户提示。系统提示、工具集和整体 agent harness 在其他方面是相同的。

【Claude Code】长时间运行 agents 的有效控制框架》 是转载文章,点击查看原文


相关推荐


《 Linux 修炼全景指南: 七 》 指尖下的利刃:深入理解 Vim 的高效世界
Lenyiin2025/11/28

摘要 本篇《Linux Vim 入门指南》从零开始,系统而全面地介绍了 Vim 的操作理念、基础模式、光标移动、文本编辑、搜索替换、可视化模式、多窗口与多文件协作等核心能力,并深入讲解 Vim 配置、插件体系与高效编辑技巧。文章不仅涵盖新手最容易踩的坑,还通过实战示例带你完成一次完整的编辑任务,使读者不但 “会用 Vim”,更真正理解 Vim 背后的高效思维方式。无论你是 Linux 新手,还是想进一步提升编辑效率的开发者,这篇指南都将成为你学习 Vim 的最佳起点。 1、引言:为什么学 Vi


【鸿蒙开发案例篇】定点出击!鸿蒙6.0视频碰一碰流转+实时进度同步案例
威哥爱编程2025/12/14

兄弟们抄家伙!今天V哥要用鸿蒙6.0的分布式能力撕碎视频跨设备流转的防线!目标:手机碰一下车机/平板,视频秒级切换+进度毫秒级同步,全程零手动干预!以下基于HarmonyOS 6.0(API 21)的ArkTS实战核弹代码已就位👇 联系V哥获取 鸿蒙学习资料 🔥 一、技术架构:分布式视频作战链 核心武器库: 碰一碰触发:NFC+分布式设备管理(@ohos.distributedDeviceManager) 进度同步引擎:AVSession Kit(@kit.AVSessionKit) 数


Flutter 开发实战:解决华为 HarmonyOS 任务列表不显示 App 名称的终极指南
雨夜寻晴天2025/12/22

问题背景 在 Flutter 应用开发中,我们最近遇到了一个棘手的兼容性问题:在部分 华为手机(HarmonyOS 4.2.0,如 Mate 30 Pro 5G) 上,应用运行时的最近任务列表(Overview Screen)中,只显示应用图标,却不显示应用名称(App Name)。 虽然我们在 AndroidManifest.xml 中正确配置了 android:label,但在 HarmonyOS 系统上依然无效。这不仅影响用户体验,也可能导致应用在审核时被拒(如华为应用市场审核指南第 2.


Pico裸机2(汇编基础)
fanged2026/1/1

既然都裸机了,还是简单回顾一下汇编吧。。。 1 概念 来自:https://redfoxsec.com/blog/introduction-to-assembly-language/ 汇编基本上就是机器码。汇编语言是一种直接对应处理器指令集的低级语言,它以人类可读的形式表达机器指令,是软件与硬件之间几乎最底层的一层接口;每一条汇编指令几乎都能映射为一条机器指令,能够精确控制寄存器、内存、指令顺序和硬件状态,因此被广泛用于启动代码、中断处理、上下文切换和性能或时序极端敏感的场景。


RAG索引流程详解:如何高效解析文档构建知识库
北辰alk2026/1/9

引言:为什么文档解析是RAG的基石? 在RAG(检索增强生成)系统中,文档解析是整个知识库构建的第一步,也是最关键的一步。就像建房子需要打好地基一样,良好的文档解析质量直接决定了后续检索和生成的效果。今天,我们就深入探讨RAG索引流程中的文档解析技术。 一、RAG文档解析的整体架构 首先,让我们通过一个流程图了解完整的解析流程: ┌─────────────────┐    ┌─────────────────┐    ┌─────────────────┐ │                 


【SpringBoot】从学会使用maven开始
那我掉的头发算什么2026/1/17

🎬 那我掉的头发算什么:个人主页 🔥 个人专栏: 《javaSE》《数据结构》《数据库》《javaEE》 ⛺️待到苦尽甘来日 引言 当我们在创建一个新的idea项目时,不知道大家注意过没有 在这个页面中除了IntelliJ选项之外,还有一个Maven选项。而这个Maven恰好就是我们今天这篇文章的重头戏! 文章目录 引言创建Maven项目pom文件项目基本信息GAVproperties依赖管理核心:dependencies与depe


CSDN创作变现活动!社区镜像或使用视频教程分别单个最高得 80 元,收益上不封顶!
CSDN官方博客2026/1/26

CSDN AI 社区是聚焦 AI 技术产业落地的开发者服务平台(官方入口),核心为创作者搭建技术价值转化桥梁,AI社区涵盖: 镜像市场(社区镜像)、算力市场等模块。 本次推出镜像创作激励活动,以下是方案活动规则、参与要求及激励政策,保障创作者权益与活动有序开展。 一、活动总则 活动时间: 2026年1月1日 - 2026年2月28日 现金奖励: 1、按照官方指定镜像任务创作,单个社区镜像奖励 30-80元现金

首页编辑器站点地图

本站内容在 CC BY-SA 4.0 协议下发布

Copyright © 2026 XYZ博客