技术1 阅读

当工具越来越多:Vercel AI SDK Tool 的边界与痛点

上一篇, 我们已经实现了: 你在 Next.js 里写几个 tool(...),把查时间、查天气之类的函数包装一下,就能让模型自动调用这些能力。

只靠这一招,你已经可以做出不少实用的小东西:内部客服助手、知识库问答、SaaS 里的 AI 小功能。

那问题来了:如果你继续往前走,会怎样?

这时候,单靠「Vercel AI SDK Tool」这一层,就开始吃力了。这篇文章,我们不急着上 MCP,先把「纯 Tool 架构」会遇到的问题摊开来讲清楚。

1. 回顾:只有 Tool 的理想世界

先快速回顾一下「上一集」的模型:

从架构图上看,大概是这样一个扁平结构:

用户 → Next.js API Route → Vercel AI SDK → 模型 模型 ←→ Tool(封装了你的业务函数)

所有东西都在一个项目里:

对一个「单应用、单团队」的项目来说,这非常舒服:

2. 第一层复杂度:工具数量暴涨带来的维护压力

我们先不引入「多个应用」「多个宿主」,只看同一个项目内部。

2.1 从「几个工具」到「一堆工具」

想象一下你在做一个后台运营助手,大概会有这些 Tool:

每一个 Tool 本身不复杂,但加起来就是几十个文件:

从短期看,这没什么问题,Tool 就是你项目的「AI 层 API 网关」

2.2 代码开始出现三类「重复与分裂」

随着工具数量上来,会出现三个微妙的问题:

  1. 同一类业务能力被重复封装

    • 你的老后端已经有一套「业务 API」,现在又在 Tool 层再封装一遍。

    • 如果别的项目也要用这些能力,又得再封装一次(在它们自己的 Tool 里)。

  2. 类型和校验规则分散

    • 原本领域模型(订单、工单、用户)在后端已经有类型和校验。

    • Tool 层又写一遍 JSON Schema / Zod,很容易有一天出现「没一起改」的问题。

  3. 权限逻辑散落在多个 Tool 中

    • 你可能在每个 Tool 的 execute 里做「当前用户是否有权限操作这个订单」之类的检查。

    • 这看起来没错,但当几十个 Tool 都做类似的检查时,想全局收紧/放宽某个权限就会很不好改。

这个阶段,纯 Tool 架构还完全能扛住,只是维护体验开始变差。你会开始想: 能不能把「工具层」变成一个更独立、可复用的东西,而不是紧紧绑死在这个项目里?

这就是往 MCP 那个方向迈出的第一小步,但我们先不着急。

3. 第二层复杂度:调用环境从一个变多个

再往前走一步:工具不只给你当前这个 Web 应用用,还想给别的宿主用。

3.1 多个宿主的典型场景

你可能会有这样的需求组合:

这三种宿主的共同点是: 都希望调用「同一套业务能力」

如果你只用 Vercel AI SDK 的 Tool,每个宿主大概率要做同样的事情:

长期看,这会变成典型的「一堆孤岛」:

3.2 这其实是「缺少协议层」的问题

注意,这个问题已经超出了「某个 SDK 好不好用」的范畴,它更像是:

我们公司内部有没有一个「统一的 AI 工具接入层」? 还是说,每个项目都自己搞一套?

Vercel AI SDK 做得很好的一件事是:在「模型调用」这一段帮你统一了不同厂商的接口。 但它不负责回答「工具怎么对外暴露,怎么被不同宿主共享」,这就刚好留给 MCP 一类协议发挥空间。

4. 第三层复杂度:跨团队协作与对外发布

再往上一个维度,你不只是「内部复用」,而是想把工具当成「产品」发布出去。

4.1 你想做的变成「工具平台」

比如你团队开发了一套非常好用的:

你会开始有这些诉求:

这时候,「只是写一些 Vercel AI SDK Tool」已经不够了:

Anthropic 提出的 Model Context Protocol(MCP),就是在这一层做文章:

你可以把它看成是:

5. 站在 AI SDK 视角,具体有哪些「边界」?

回到 Vercel AI SDK 这个具体产品,结合官方文档和社区讨论,可以把「只靠 Tool」的边界/痛点总结为几类。

5.1 Tool 的适用范围主要在「应用内部」

AI SDK 官方定位是:帮助你在 Next.js、Node.js 等环境里快速构建 AI 应用和 Agent。 它的 Tool 抽象也主要围绕这个目标设计:

但它并不是一个「对外标准」:

5.2 生态角度:每家 SDK 都有自己的 Tool 抽象

不仅是 Vercel AI SDK,LangChain、LlamaIndex、各种自研 Agent 框架都有自己的「工具定义」方式。

如果你只停留在 SDK 层(包括 AI SDK 的 Tool),你会发现:

MCP 这种协议试图解决的,就是这个「SDK 之上」的问题:让工具变成一个可以跨框架、跨产品、跨公司的「公共语言」。

5.3 一些实践反馈:当项目复杂时,你会自己补一层「平台」

社区里已经有不少重度使用 Vercel AI SDK 的开发者在讨论:

这本质上也是一种「协议化」趋势: 只是这个协议目前还停留在「你所在组织内部」的层次,而 MCP 把它开放成了生态级标准。

6. 从 Tool 视角看 MCP:我们到底缺了哪一层?

我们可以用一个很实用的类比来总结一下前面的讨论。

站在 Vercel AI SDK Tool 的视角看:

两者不冲突,只是站的高度不同:

7. 为下一篇做铺垫:我们会怎么用 MCP?

这篇我们刻意没有深入 MCP 的技术细节,只是从「Tool 用到头了会怎样」的角度,把它的动机讲明白了:

下一篇,我们会集中火力聊 MCP 本身:

SHARE

分享

分享这篇文章。