By 小墨
2026年4月24日
75
525
800行代码实现OpenClaw的Tool、消息总线、子Agent管理架构
在Agent系统开发中,如何平衡抽象层次与工程确定性是一个核心命题。当业界普遍依赖LangChain等框架时,一个有趣的设计思路是采用薄抽象、显式控制流的方式,直接面向API构建系统。本文将详细介绍一个基于Anthropic Claude API的轻量级Agent框架实现,展示如何在800行代码内构建Tool系统、消息总线和子Agent管理三大核心模块。
概述
MessageBus处理入站方向的消息流,实现从子系统或外部到主Agent的消息传递。其核心是订阅-发布模式,InboundMessage包含channel(消息通道)、senderId(发送者标识)、chatId(关联会话)和content(消息内容)四个字段。 MessageBus提供了两种消费模式:subscribe注册实时回调,适合常驻服务场景;drain从队列中取出并清空消息,适合轮询式的同步消费场景。路由规则清晰:有订阅者走回调,无订阅者入队列。消息只走一条路径,不会同时触发回调和入队。这种设计避免了消息处理的歧义性。 需要明确的是,MessageTool负责出站(Agent→外部),MessageBus负责入站(外部→Agent),两者方向相反,没有直接的代码耦合。这种解耦设计使得消息流清晰可追踪。
消息总线:入站消息的统一枢纽
整个系统存在两条数据流主线: 同步路径:用户输入→REPL→agent.run()→工具调用→结果回传模型→最终回复→stdout。这是标准的ReAct循环。 异步路径:SpawnTool/CronService→bus.publish(system)→handler入队→tryDrainPending()→agent.run()处理系统通知→stdout。异步结果通过MessageBus汇入主循环,由互斥锁保证不与同步路径冲突。 这种设计使得同步和异步操作能够有序共存,不会产生状态混乱。切换接入层(从REPL到Bot)时,只需替换sendCallback和输入源,工具系统和Agent逻辑无需任何改动。
中间层越薄,调试越容易,对API行为的控制越精确。
“设计原则”模块协作与数据流
REPL(Read-Eval-Print Loop)是整个Agent的终端交互入口。核心挑战在于:用户输入和子Agent回传结果都可能触发agent.run(),但history数组是共享的,不能并发修改。 解决方案是布尔互斥锁配合暂存队列。processing标志充当互斥锁,确保同一时刻只有一个agent.run()执行。子Agent结果到达时先push到pendingSubagentResults数组,tryDrainPending只在非processing状态下进入,避免并发写入history。用户交互完成后,在释放锁之前调用drainPendingResults处理积攒的子Agent结果,保证结果不会无限滞后。 启动流程按以下顺序初始化:创建Anthropic客户端和MessageBus实例→注册工具到ToolRegistry(区分主Agent和子Agent工具集)→初始化CronService→创建SubagentManager→构建ContextBuilder→创建AgentLoop并启动交互循环。
设计哲学与局限
这个框架的核心设计哲学可以概括为四个要点:薄抽象层带来的调试优势、显式控制流带来的可追踪性、零框架依赖带来的完全控制力、以及贴近SDK设计带来的类型安全。 当然,设计也存在局限:子Agent无持久记忆,不适合需要跨任务积累上下文的场景;CronService的cron表达式是近似实现,不支持精确时间点语义;MessageBus无持久化,进程重启后消息丢失;ExecTool的正则黑名单只是最低防线,生产环境应该使用容器沙箱;REPL的布尔锁在多用户场景下需要更完整的队列机制。 这些取舍反映了「先跑起来,再逐步完善」的工程思路。框架的可扩展性已经预留好了空间:扩展新工具只需继承Tool并注册,切换接入层只需替换回调,输入源的变化不会影响核心逻辑。
如有侵权,请联系删除。
Related Articles
-
Sun May 10 2026AI智能体与未来继续教育智慧化发展变局
国家多部门发布的智能体实施意见将教育列为重要应用场景,继续教育因其用户基础广泛与场景碎片化成为智能体落地的优先领域之一。
-
Sun May 10 2026字节 2026 年资本开支或冲 300 亿美元,AI 算力军备赛再加码/百度发布文心 5.1,主打「多维弹性预训练」面向开发者开放
近日行业报道显示,字节跳动计划在2026年显著提升资本开支以支撑AI业务扩张,与此同时百度推出文心5.1,强调多维弹性预训练并向开发者开放。此轮动作被视为国内在算力和大模型层面的一次重要加速。
-
Sat May 09 2026376亿,最牛AI独角兽又融资了
Kimi在2026年持续获得多轮机构投资,本次新一轮融资使其估值大幅上升,显示出技术与市场双重认可的趋势。
-
Sat May 09 2026突破!OpenAI与普华永道联手推出AI原生财务系统!
2026年5月,OpenAI与普华永道宣布启动合作,旨在构建首个面向大型企业的AI原生财务运营系统,通过智能体技术提升财务流程的自动化与决策效率。
-
Sat May 09 20262026 IDC 中国 CIO 峰会:迈向代理式 AI 新纪元,共启智能体驱动新范式
2026年IDC中国CIO峰会将于5月15日在深圳举行,主题聚焦代理式AI的新范式,旨在帮助企业技术决策者理解从生成式AI向代理式AI演进的路径与实践案例。
-
Sat May 09 2026磅旗黑科技登陆 CIBF,新能源工厂迈入工业 AI 智能体时代
磅旗科技在CIBF展会上展示了面向新能源领域的工业AI智能体解决方案,构建数字白领(脑力类自动化)与数字蓝领(设备与执行层自动化)双体系,推动工厂业务从信息化向智能体驱动的自動化升级。
-
Sat May 09 2026技术创新峰会——智见下一个十年,解构AI基础设施关键技术突破与落地应用实践
NAVIGATE 2026领航者峰会的技术创新分会聚焦智能体时代对基础设施的新要求,讨论从算力堆叠到系统协同的技术路线,强调解决大模型推理带来的海量Token消耗问题。
-
Sat May 09 2026Agent打开AI新局面
AI Agent作为AI大模型商业化的重要形式,正从技术工具逐步演进为新型生产要素,在企业流程自动化与决策支撑中发挥核心作用。
-
Sat May 09 2026AI 褪去聊天属性,正式进入全民办公生产力时代
2026年5月出现行业转折,AI从以聊天为主的交互工具转向面向企业生产力的基础设施,更多公司将AI作为日常办公和业务流程提升的核心工具。
-
Sat May 09 2026博云发布 BoAgent 智能体平台 以安全可信 Agentic AI 重构企业数字生产力
2026年5月8日,博云科技在发布会上推出BoAgent智能体平台,面向政企级市场提供一套可工程化落地的企业级智能体解决方案。该平台主打高安全与强合规,支持端到端复杂业务任务的自主完成。
-
Sat May 09 20262026,AI Agent元年:会自动干活的AI,正在改变职场
2026年,智能体被广泛讨论并被写入多项政策文件和政府报告,行业与监管共同推动其规范化与规模化应用,AI从“会说”进入“会做”的新时代。
-
Fri May 08 2026亿元级A+轮融资背后:未来智能的"硬件新物种"实验,一场关于AI Agent入口的豪赌
本文通过对未来智能完成亿元级A+轮融资并引入传音作为战略合作者的事件分析,探讨硬件与软件协同在AI Agent落地过程中的关键作用。
-
Fri May 08 2026AI 智能体人才标准重磅发布,51CTO深度参编赋能数智人才高质量发展
第五届中国国际软件发展大会发布了《AI智能体应用开发工程师能力评价标准》,由中国软件行业协会教育与培训分会牵头,联合多家高校与企业共同制定,旨在规范智能体开发者的能力模型與评价方法。
-
Fri May 08 2026未来智能拿到传音投资,AI耳机可能是个人Agent的第一块硬件入口
未来智能宣布获得传音参与的亿元级A轮融资,双方将展开战略合作,联合推进下一代具备自主感知、决策与执行能力的AI Agent硬件研发。此次融资为未来智能在算法、芯片与产品形态上的整合升级提供了重要资本与
-
Fri May 08 2026用友BIP超级版亮相2026移动云大会,云智融合赋能企业驾驭AI新范式
用友在2026移动云大会上推出了BIP超级版,强调AI原生架构与云边协同,以支持企业在财务、人力与供应链等核心业务领域实现智能化升级。
-
Fri May 08 2026国家队领投 DeepSeek 首轮融资,估值约 450 亿美元!
2026年5月,国家集成电路产业投资基金牵头完成对DeepSeek的首轮融资谈判,投后估值接近450亿美元,此次融资引发业界广泛关注并被视为国家层面对顶尖大模型企业的战略投入。
-
Fri May 08 20262026年5月8日
本文为2026年5月8日的行业日报,汇总当天涉及芯片、模型、开源、企业应用与研究报告等多方面的重大进展,帮助读者在碎片化信息中把握行业脉络。
-
Fri May 08 2026阿里 京东 百度押注具身智能 多家AI公司递表 Open AI估值8500亿美元
2026年4月,阿里、京东、百度等国内巨头纷纷在具身智能领域加大投入,行业内多家AI公司陆续提交上市申请或融资计划,展示出从算法到产品化落地的加速态势。
