Forge Guardrails:本地 8B 模型能不能跑生产级工具调用 Agent?
本地 LLM 做 Agent,最容易被低估的不是模型能不能回答问题,而是它能不能稳定地把一串工具调用跑完。 这句话听起来有点扫兴。毕竟现在 7B、8B、14B 模型的 benchmark 分数越来越好,Ollama、llama.cpp、llama-server 也把本地部署门槛降到了很低。我之前写过一篇 本地 LLM 推理工具的取舍,当时重点放在推理后端、模型格式和生态锁定上。但如果你真的想把本地模型接进自动化工作流,另一个问题会更快冒出来:模型单步看起来不错,多步之后为什么还是崩? HN 上这两天有个项目 Forge 很适合拿来讨论这个问题。它的标题很抓人:“Guardrails take an 8B model from 53% to 99% on agentic tasks”。我对这种数字一向谨慎,因为 agentic task 的定义、评测场景和采样参数都会强烈影响结果。但 Forge 真正值得看的地方,不是“8B 追平 frontier model”这个营销点,而是它把本地 Agent 失败拆成了几个非常工程化的小故障:工具调用解析失败、走错步骤、错误恢复失败、上下文预算失控,以及多个工作流争用同一个 GPU 推理槽。 说白了,它不是在训练一个更聪明的模型,而是在给一个不够稳定的模型加流程控制。 为什么本地 Agent 会在多步任务里快速掉队 很多人第一次做工具调用 Agent,会拿一个天气查询、数据库查询或者代码搜索 demo 开始。模型需要做的事情很简单:读用户问题,选择工具,填参数,拿结果,再回答。单步成功率只要看起来有 90%,体验就会很好。 问题出在复合任务上。 假设一个工作流有 5 步,每一步成功率都是 90%。如果这些步骤必须全部正确,整体成功率不是 90%,而是 0.9 的 5 次方,大约 59%。这还是独立错误的理想情况;真实 Agent 里,前一步的轻微偏差会污染后续上下文,错误会复利。 Forge 作者在 HN 发布帖 里也用了类似的“compounding math”解释:本地模型每一步都不算太差,但连续工具调用会把小错误放大成任务失败。这其实是我最认同它的地方。生产环境的 Agent 可靠性,很多时候不是靠“再换一个大模型”解决,而是靠把可控部分从自然语言里拿出来,交给确定性系统。 这也是为什么我会把 Forge 和之前写过的 Statewright 状态机护栏 放在同一类问题里看。Statewright 更偏“限制 Agent 在什么阶段能做什么”,Forge 更偏“当模型工具调用出错时,如何修、如何重试、如何阻止它跳步骤”。两者的共同点是:它们都不再迷信一个超长 system prompt。 ...