在《查看了300+ MCP Server之后【关注微信公众号:wwwtangshuangnet】【作者:唐霜】,我认为这个生态要祛魅了……》一文中,我数落了MCP生态的一些不足,著作权归作者所有,禁止商业用途转载。转载请注明出处:www.tangshuang.net以及抨击了媒体过分吹捧MCP的现象。但这【版权所有,侵权必究】【转载请注明来源】并不代表我完全否定了MCP的意义。今天Q【版权所有,侵权必究】转载请注明出处:www.tangshuang.netwen3再次刷新了基础模型的能力,其中一本文版权归作者所有,未经授权不得转载。【版权所有,侵权必究】项重要特征在于对Agent的支持优化,以本文版权归作者所有,未经授权不得转载。【版权所有】唐霜 www.tangshuang.net及对MCP的针对性优化。足以见得,202【转载请注明来源】【访问 www.tangshuang.net 获取更多精彩内容】5年会是Agent应用真正被市场认可的一【转载请注明来源】【本文首发于唐霜的博客】年。
【原创不易,请尊重版权】原创内容,盗版必究。【原创内容,转载请注明出处】MCP虽然是由Anthropic一家公司本文作者:唐霜,转载请注明出处。未经授权,禁止复制转载。提出来的,但随着社区生态的壮大,它也会成【转载请注明来源】本文作者:唐霜,转载请注明出处。为未来“2A”(面向AI,这个是我提出来本文作者:唐霜,转载请注明出处。【原创不易,请尊重版权】的哈,现在我们终于从2C, 2B,到了2转载请注明出处:www.tangshuang.net【关注微信公众号:wwwtangshuangnet】A)类应用的基础协议之一,用以对接来自不本文作者:唐霜,转载请注明出处。【未经授权禁止转载】同服务商、本地软件、云端函数、其他AI应【版权所有】唐霜 www.tangshuang.net【版权所有】唐霜 www.tangshuang.net用(如其他Agent等)的应用层通信协议著作权归作者所有,禁止商业用途转载。【本文首发于唐霜的博客】(虽然google提出来A2A协议,但是在未经授权,禁止复制转载。【未经授权禁止转载】我看来落地困难,一个本质的点在于,Age著作权归作者所有,禁止商业用途转载。【未经授权禁止转载】nt本身也可以通过API来调用,基于MC【关注微信公众号:wwwtangshuangnet】本文版权归作者所有,未经授权不得转载。P封装API也可以实现Agent之间的通【转载请注明来源】【转载请注明来源】信,如果“我们不需要太多协议”是共识,那【本文首发于唐霜的博客】著作权归作者所有,禁止商业用途转载。么A2A协议就没有必要存在)。但是,普通开发者(特指基于LLM的A【关注微信公众号:wwwtangshuangnet】本文版权归作者所有,未经授权不得转载。I应用开发者)立即接入MCP却并不容易。
未经授权,禁止复制转载。未经授权,禁止复制转载。著作权归作者所有,禁止商业用途转载。正如我上篇文章中提到的,MCP只解决了工著作权归作者所有,禁止商业用途转载。【本文首发于唐霜的博客】具的注册和调用问题,但未解决客户端与大模【版权所有,侵权必究】本文作者:唐霜,转载请注明出处。型的交互痛点。因此,我打算开发一个服务,著作权归作者所有,禁止商业用途转载。【转载请注明来源】让开发者们可以以原始的API方式,接入到【关注微信公众号:wwwtangshuangnet】【作者:唐霜】MCP生态中,抢先体验MCP生态带来的便著作权归作者所有,禁止商业用途转载。【原创不易,请尊重版权】利。于是,MCP Bone这个项目诞生了原创内容,盗版必究。转载请注明出处:www.tangshuang.net。通过这个项目,我既对MCP的服务器开发【转载请注明来源】【作者:唐霜】有了一定了解,同时,也从产品层面对MCP【作者:唐霜】本文作者:唐霜,转载请注明出处。的生态构建有了一定的思考。接下来,我就将【作者:唐霜】本文作者:唐霜,转载请注明出处。通过这篇文章,详细拆解我是如何构建MCP本文作者:唐霜,转载请注明出处。【版权所有】唐霜 www.tangshuang.net Bone的,以及,我在这个过程中所接触著作权归作者所有,禁止商业用途转载。本文作者:唐霜,转载请注明出处。的MCP开发方面的趣闻思考。
本文作者:唐霜,转载请注明出处。原创内容,盗版必究。未经授权,禁止复制转载。什么是MCP Bone?
在开始之前,我需要先介绍一下MCP Bo【本文受版权保护】未经授权,禁止复制转载。ne,以及我设立这个项目的目的。
【版权所有,侵权必究】【版权所有】唐霜 www.tangshu【原创不易,请尊重版权】【本文首发于唐霜的博客】ang.netMCP Bone是一个在线服务,用以帮助【作者:唐霜】未经授权,禁止复制转载。开发者降低接入MCP生态的难度。开发者可【转载请注明来源】原创内容,盗版必究。以在MCP Bone的页面上,以简单的方著作权归作者所有,禁止商业用途转载。【版权所有】唐霜 www.tangshuang.net式,注册自己应用可能涉及的MCP Ser【本文首发于唐霜的博客】【转载请注明来源】ver,这些MCP Server会运行在【未经授权禁止转载】未经授权,禁止复制转载。云端,随后,开发者可以通过传统的Rest【版权所有】唐霜 www.tangshuang.net【访问 www.tangshuang.net 获取更多精彩内容】ful接口形式,从MCP Bone获取用转载请注明出处:www.tangshuang.net【访问 www.tangshuang.net 获取更多精彩内容】于与大模型交互的function cal【访问 www.tangshuang.net 获取更多精彩内容】原创内容,盗版必究。ling tools,或包含特定模式的p著作权归作者所有,禁止商业用途转载。【原创内容,转载请注明出处】rompt文本,用以与大模型进行交互。通【转载请注明来源】【原创内容,转载请注明出处】过这种开发方式的设计,MCP Bone让【转载请注明来源】本文作者:唐霜,转载请注明出处。开发者完全不需要自己去构建和部署MCP服【原创不易,请尊重版权】【版权所有】唐霜 www.tangshuang.net务器,就可以让自己的在线应用接入MCP生【转载请注明来源】【未经授权禁止转载】态。它就像一个MCP Server的集装转载请注明出处:www.tangshuang.net【未经授权禁止转载】箱,把复杂的MCP生态部署、通信等封装在未经授权,禁止复制转载。【转载请注明来源】集装箱中,使开发者从外部来看,变得异常简原创内容,盗版必究。本文版权归作者所有,未经授权不得转载。单(就像传统调API接口一般,不需要任何【版权所有,侵权必究】著作权归作者所有,禁止商业用途转载。心智负担)。
本文作者:唐霜,转载请注明出处。本文作者:唐霜,转载请注明出处。 未经授权,禁止复制转载。原创内容,盗版必究。【本文受版权保护】【版权所有,侵权必究】或许这样讲你还不是很理解,没关系,随着下【本文首发于唐霜的博客】【转载请注明来源】文一点点的展开,你会对MCP Bone有【本文受版权保护】本文作者:唐霜,转载请注明出处。非常清晰的认识。
【访问 www.tangshuang.n【访问 www.tangshuang.net 获取更多精彩内容】【作者:唐霜】et 获取更多精彩内容】转载请注明出处:www.tangshua【原创不易,请尊重版权】【未经授权禁止转载】ng.net著作权归作者所有,禁止商业用途转载。当然,本文不是为了推广MCP Bone,【未经授权禁止转载】【本文首发于唐霜的博客】而是向你展示一个MCP项目从设想到开发到【本文受版权保护】本文作者:唐霜,转载请注明出处。上线的全过程。希望你也在开发MCP相关项本文作者:唐霜,转载请注明出处。转载请注明出处:www.tangshuang.net目时,有所借鉴。
【本文受版权保护】【版权所有,侵权必究】【本文受版权保护】好了,现在我们开始吧🤜
原创内容,盗版必究。原创内容,盗版必究。【作者:唐霜】MCP Server的在线化服务搭建
MCP经过几个版本的迭代,现在已经非常清转载请注明出处:www.tangshuang.net【版权所有,侵权必究】晰,通过transport来划分,MCP【作者:唐霜】本文版权归作者所有,未经授权不得转载。 Server可以分为stdio和htt【版权所有】唐霜 www.tangshuang.net【版权所有】唐霜 www.tangshuang.netp-stream两类。但是因为历史原因,转载请注明出处:www.tangshuang.net【本文受版权保护】目前生态中大部分都是stdio模式。这种【版权所有】唐霜 www.tangshuang.net转载请注明出处:www.tangshuang.net模式的初衷,是一开始他们认为MCP Se【访问 www.tangshuang.net 获取更多精彩内容】【关注微信公众号:wwwtangshuangnet】rver会大多是本地电脑上的程序,通过s本文版权归作者所有,未经授权不得转载。【原创内容,转载请注明出处】tdio模式提供给Claude这样的客户【原创内容,转载请注明出处】【原创内容,转载请注明出处】端使用。然而,随着时间发展,他们发现,很【本文受版权保护】原创内容,盗版必究。多的MCP Server可能并不在本地电本文作者:唐霜,转载请注明出处。【原创不易,请尊重版权】脑上运行,但是由于协议的限制,最后很多都本文版权归作者所有,未经授权不得转载。【转载请注明来源】用stdio模式来伪装其在线服务的本质。
【本文首发于唐霜的博客】本文作者:唐霜,转载请注明出处。【本文受版权保护】新版本的sdk中,http-stream本文版权归作者所有,未经授权不得转载。【作者:唐霜】模式(内置了认证功能)已经成为官方主推模【作者:唐霜】本文版权归作者所有,未经授权不得转载。式。通过http-stream模式,各个【版权所有,侵权必究】【版权所有】唐霜 www.tangshuang.net厂商不再需要分发npm/pyi包了,直接【作者:唐霜】【本文首发于唐霜的博客】向开发者们提供MCP Server的ht本文作者:唐霜,转载请注明出处。【本文首发于唐霜的博客】tp服务器的连接信息即可。
【原创不易,请尊重版权】【版权所有】唐霜 www.tangshu【版权所有】唐霜 www.tangshuang.net【访问 www.tangshuang.net 获取更多精彩内容】ang.net【版权所有,侵权必究】但是,这样又会出现新的问题。一家厂商,只本文作者:唐霜,转载请注明出处。转载请注明出处:www.tangshuang.net要业务不止一个,不太可能只提供一个MCP【版权所有】唐霜 www.tangshuang.net【转载请注明来源】 Server。像那些一线厂商,业务线很【版权所有】唐霜 www.tangshuang.net【转载请注明来源】长,可能会有几百上千的MCP Serve【原创内容,转载请注明出处】本文版权归作者所有,未经授权不得转载。r发布出来,形成混乱局面。此时,必然会出【本文首发于唐霜的博客】未经授权,禁止复制转载。现一个叫做“MCP Server集群”的【版权所有】唐霜 www.tangshuang.net【转载请注明来源】东西,用以管理这些在线MCP Serve著作权归作者所有,禁止商业用途转载。原创内容,盗版必究。r。
【作者:唐霜】著作权归作者所有,禁止商业用途转载。不过就目前而言,市面上还是以stdio模【作者:唐霜】【原创不易,请尊重版权】式的MCP Server为主,即使它们本本文作者:唐霜,转载请注明出处。原创内容,盗版必究。质上还是在内部调远端的服务接口。这就带来【本文首发于唐霜的博客】【访问 www.tangshuang.net 获取更多精彩内容】一个问题,即这些stdio模式的MCP 本文版权归作者所有,未经授权不得转载。未经授权,禁止复制转载。Server,如何能在线化服务?例如,你【原创不易,请尊重版权】著作权归作者所有,禁止商业用途转载。司开发了一个可以利用ffmepg实现视频【关注微信公众号:wwwtangshuangnet】【版权所有】唐霜 www.tangshuang.net风格转化的功能程序,它在本地CLI中运行未经授权,禁止复制转载。本文版权归作者所有,未经授权不得转载。良好,并发布了MCP Server。但是本文作者:唐霜,转载请注明出处。【版权所有,侵权必究】你司老板很快发现,这东西为什么不包装一下【访问 www.tangshuang.net 获取更多精彩内容】未经授权,禁止复制转载。挣钱呢?于是要求你不再开源它,而是把它部【版权所有,侵权必究】【关注微信公众号:wwwtangshuangnet】署到公司服务器上,让其他公司通过API 本文作者:唐霜,转载请注明出处。【版权所有】唐霜 www.tangshuang.netKey来调用。虽然你们的程序本身可以在服本文版权归作者所有,未经授权不得转载。本文版权归作者所有,未经授权不得转载。务器上良好运行,但是MCP Server本文版权归作者所有,未经授权不得转载。【关注微信公众号:wwwtangshuangnet】在线化服务又绊住你的脚。在http-st原创内容,盗版必究。【本文首发于唐霜的博客】ream模式成为你的标准选项之前,你需要【未经授权禁止转载】【版权所有】唐霜 www.tangshuang.net寻找一种简单且高效的迁移方案。
【版权所有】唐霜 www.tangshu【本文受版权保护】转载请注明出处:www.tangshuang.netang.net【本文首发于唐霜的博客】未经授权,禁止复制转载。本文版权归作者所有,未经授权不得转载。这就是我们要讨论的MCP Server在【本文受版权保护】【作者:唐霜】线化问题。即如何将原来本地运行的MCP 【版权所有】唐霜 www.tangshuang.net未经授权,禁止复制转载。Server,迁移到服务器上提供服务。目转载请注明出处:www.tangshuang.net【访问 www.tangshuang.net 获取更多精彩内容】前,阿里系的魔搭社区、七牛云都在赶这一趟【原创不易,请尊重版权】未经授权,禁止复制转载。快车,提供了在线化的服务。但作为小厂商,【版权所有】唐霜 www.tangshuang.net原创内容,盗版必究。你有没有办法自己搞定呢?当然有!
本文版权归作者所有,未经授权不得转载。【版权所有,侵权必究】我们找到一个叫mcp-connect的项目,这个项目将stdio模式的MCP转载请注明出处:www.tangshuang.net【本文首发于唐霜的博客】 Server转化为一个http ser著作权归作者所有,禁止商业用途转载。【未经授权禁止转载】ver,从而可以对外提供在线化服务。
【本文首发于唐霜的博客】【本文受版权保护】
它不仅是把单个MCP Server在线化【未经授权禁止转载】【关注微信公众号:wwwtangshuangnet】,而是可以同时提供任意多的MCP Ser【本文受版权保护】本文作者:唐霜,转载请注明出处。ver在线化能力。你不仅把你司的这个程序【未经授权禁止转载】【未经授权禁止转载】的MCP Server放到了服务器上,还【版权所有】唐霜 www.tangshuang.net未经授权,禁止复制转载。把来自其他厂商的开源MCP Server转载请注明出处:www.tangshuang.net著作权归作者所有,禁止商业用途转载。也同时放了进去,形成了一个“MCP Se【未经授权禁止转载】【原创不易,请尊重版权】rver集群”。你不仅完成了老板交代了的【版权所有】唐霜 www.tangshuang.net【本文首发于唐霜的博客】任务,而且在汇报PPT的最后一页,浓墨重本文作者:唐霜,转载请注明出处。【关注微信公众号:wwwtangshuangnet】彩的规划了公司在MCP架构上的基础理论。【本文受版权保护】本文版权归作者所有,未经授权不得转载。我相信,这一举动,会让老板对你高看一眼。
【本文受版权保护】【关注微信公众号:wwwtangshua【关注微信公众号:wwwtangshuangnet】本文作者:唐霜,转载请注明出处。ngnet】【原创不易,请尊重版权】但是,mcp-connect只解决了MC本文作者:唐霜,转载请注明出处。【原创不易,请尊重版权】P Server的在线化,它内置了一个非转载请注明出处:www.tangshuang.net转载请注明出处:www.tangshuang.net常粗糙的access_token认证,没【转载请注明来源】【版权所有,侵权必究】有解决多用户认证等问题。MCP Bone著作权归作者所有,禁止商业用途转载。本文作者:唐霜,转载请注明出处。是怎么解决的呢?
【关注微信公众号:wwwtangshua【关注微信公众号:wwwtangshuangnet】【作者:唐霜】ngnet】【版权所有,侵权必究】著作权归作者所有,禁止商业用途转载。【版权所有,侵权必究】MCP Bone基于这套方案,将基于mc【原创内容,转载请注明出处】转载请注明出处:www.tangshuang.netp-connect的体系部署为后端服务。著作权归作者所有,禁止商业用途转载。本文作者:唐霜,转载请注明出处。在自己的应用层,构建了自己的认证体系。简【版权所有,侵权必究】【本文首发于唐霜的博客】单讲,就是通过系统架构设计,通过层层设计本文作者:唐霜,转载请注明出处。【本文首发于唐霜的博客】来弥补单一生态的不足。
【版权所有】唐霜 www.tangshu【作者:唐霜】【本文受版权保护】ang.net著作权归作者所有,禁止商业用途转载。【本文受版权保护】MCP服务器注册与工具调用体系
在有了后端的MCP Server在线化支【原创内容,转载请注明出处】【转载请注明来源】持后,就是应用层构建。首当其冲的,就是M未经授权,禁止复制转载。未经授权,禁止复制转载。CP协议(在我看来)的本质——工具注册和【版权所有】唐霜 www.tangshuang.net【版权所有,侵权必究】调用。
【本文首发于唐霜的博客】未经授权,禁止复制转载。著作权归作者所有,禁止商业用途转载。【本文受版权保护】MCP服务器注册与工具列表拉取
从使用简单的角度讲,我们设计一个底层为技【转载请注明来源】【本文首发于唐霜的博客】术驱动的功能时,应该尽可能的让参数少,不【原创内容,转载请注明出处】未经授权,禁止复制转载。需要暴露太多可选项给用户。MCP Bon【版权所有】唐霜 www.tangshuang.net【原创内容,转载请注明出处】e只需要用户填写一个简单的表单,即可完成【版权所有,侵权必究】原创内容,盗版必究。注册。
【版权所有】唐霜 www.tangshu【访问 www.tangshuang.net 获取更多精彩内容】【原创不易,请尊重版权】ang.net【关注微信公众号:wwwtangshua原创内容,盗版必究。【版权所有,侵权必究】ngnet】转载请注明出处:www.tangshua【访问 www.tangshuang.net 获取更多精彩内容】本文版权归作者所有,未经授权不得转载。ng.net
基于该表单,它可以生成一个mcpServ【转载请注明来源】著作权归作者所有,禁止商业用途转载。er的配置JSON:
原创内容,盗版必究。【作者:唐霜】【未经授权禁止转载】【未经授权禁止转载】
这与我们在Cursor、Cline等MC【未经授权禁止转载】【原创内容,转载请注明出处】P Host中填写的配置信息并无二致。
本文作者:唐霜,转载请注明出处。著作权归作者所有,禁止商业用途转载。原创内容,盗版必究。当用户填写的信息正确,提交之后,就可以在【访问 www.tangshuang.net 获取更多精彩内容】【原创内容,转载请注明出处】MCP Server列表看到注册好的服务【原创内容,转载请注明出处】【版权所有,侵权必究】器,并在点击查看后看到该服务器下的所有工本文作者:唐霜,转载请注明出处。本文作者:唐霜,转载请注明出处。具:
【原创内容,转载请注明出处】【未经授权禁止转载】
以上便是MCP Server的注册和工具【转载请注明来源】【未经授权禁止转载】的拉取过程。可以看到,其实非常简单,没有原创内容,盗版必究。【本文受版权保护】任何心智负担。
【作者:唐霜】【本文受版权保护】本文版权归作者所有,未经授权不得转载。本文版权归作者所有,未经授权不得转载。但是,我们在Cursor等客户端中会发现【版权所有,侵权必究】著作权归作者所有,禁止商业用途转载。一个功能,即它们提供了一个MCP Ser未经授权,禁止复制转载。未经授权,禁止复制转载。ver的列表供你一键安装。数量这么多,软【版权所有】唐霜 www.tangshuang.net【本文首发于唐霜的博客】件官方团队不可能把每一个MCP Serv本文版权归作者所有,未经授权不得转载。【本文首发于唐霜的博客】er的配置都誊抄一遍。你猜它是怎么做的?本文作者:唐霜,转载请注明出处。【关注微信公众号:wwwtangshuangnet】我想你打死也想不到,当你点击安装的时候,【原创内容,转载请注明出处】【作者:唐霜】它去抓取这个MCP Server的REA著作权归作者所有,禁止商业用途转载。【转载请注明来源】DME,然后通过LLM提取和总结它的配置未经授权,禁止复制转载。转载请注明出处:www.tangshuang.net,这个过程就和你使用Cursor写代码的【作者:唐霜】【转载请注明来源】过程是一样的。😀这也就意著作权归作者所有,禁止商业用途转载。【版权所有】唐霜 www.tangshuang.net味着不管你MCP Server的开发者多未经授权,禁止复制转载。转载请注明出处:www.tangshuang.net懒,或者升级版本多快,都不会影响它安装和著作权归作者所有,禁止商业用途转载。【版权所有】唐霜 www.tangshuang.net更新的准确性。我觉得这种玩法非常极客,是【关注微信公众号:wwwtangshuangnet】【关注微信公众号:wwwtangshuangnet】AI时代下产品该有的样子。
【本文首发于唐霜的博客】【原创不易,请尊重版权】本文版权归作者所有,未经授权不得转载。著作权归作者所有,禁止商业用途转载。有样学样,MCP Bone也提供一键式智著作权归作者所有,禁止商业用途转载。著作权归作者所有,禁止商业用途转载。能识别的能力,上面的表单虽然已经够简单了【作者:唐霜】著作权归作者所有,禁止商业用途转载。,但是还可以更简单,开发者只需要在一个文【版权所有,侵权必究】【版权所有】唐霜 www.tangshuang.net本框输入一个url,即可完成表单的填充。
未经授权,禁止复制转载。原创内容,盗版必究。【关注微信公众号:wwwtangshua【版权所有】唐霜 www.tangshuang.net【作者:唐霜】ngnet】【转载请注明来源】
工具的调用
由于MCP Bone的目标是降级开发难度【本文受版权保护】【转载请注明来源】,因此,调用MCP Server的工具,【版权所有】唐霜 www.tangshuang.net未经授权,禁止复制转载。被降级为发起一个HTTP请求,传入ser未经授权,禁止复制转载。【版权所有】唐霜 www.tangshuang.netver_name, tool_name和原创内容,盗版必究。转载请注明出处:www.tangshuang.netarguments即可,之后就可以得到运本文版权归作者所有,未经授权不得转载。【本文受版权保护】行结果。
【原创不易,请尊重版权】【转载请注明来源】后端流程上,MCP Bone在接收到开发【版权所有,侵权必究】【原创内容,转载请注明出处】者发来的调用工具请求后,将数据格式转化为著作权归作者所有,禁止商业用途转载。【关注微信公众号:wwwtangshuangnet】mcp-connect所需要的格式,并发未经授权,禁止复制转载。【未经授权禁止转载】送给mcp-connect服务,而mcp【本文受版权保护】未经授权,禁止复制转载。-connect又会将http请求转化为【本文受版权保护】【本文受版权保护】stdio交互,在具体的MCP Serv【访问 www.tangshuang.net 获取更多精彩内容】【版权所有,侵权必究】er内部,还可能去上游服务商的接口拉数据【版权所有】唐霜 www.tangshuang.net未经授权,禁止复制转载。。
【访问 www.tangshuang.n著作权归作者所有,禁止商业用途转载。【未经授权禁止转载】et 获取更多精彩内容】【本文受版权保护】【原创内容,转载请注明出处】总之,虽然后端的整个链条很复杂,但是对于【版权所有,侵权必究】【版权所有,侵权必究】MCP Bone的开发者用户而言,不需要未经授权,禁止复制转载。原创内容,盗版必究。理解这么深入的过程,只需要调用http接未经授权,禁止复制转载。未经授权,禁止复制转载。口,传入3个参数,即可完成MCP Ser【原创内容,转载请注明出处】本文作者:唐霜,转载请注明出处。ver工具调用。
未经授权,禁止复制转载。【转载请注明来源】【版权所有,侵权必究】【本文受版权保护】MCP与大模型交互适配
在进行接下来的内容之前,到目前为止,MC【转载请注明来源】本文版权归作者所有,未经授权不得转载。P Bone实现了一个“MCP Serv【作者:唐霜】【本文首发于唐霜的博客】er集群”和“调用难度降级”的效果。如果【原创内容,转载请注明出处】著作权归作者所有,禁止商业用途转载。对于新手开发者来说,他不知道MCP协议的本文作者:唐霜,转载请注明出处。原创内容,盗版必究。具体实施过程,但是想将MCP生态众多MC【原创内容,转载请注明出处】【本文受版权保护】P Server所提供的功能集成到自己的【作者:唐霜】【版权所有】唐霜 www.tangshuang.net应用中,MCP Bone正好可以满足他。【转载请注明来源】【原创内容,转载请注明出处】对于他来说,开发中,并不存在MCP的所有原创内容,盗版必究。本文版权归作者所有,未经授权不得转载。概念,而是只有“调用一个自定义功能的平台【版权所有,侵权必究】转载请注明出处:www.tangshuang.netAPI”的概念。他可能会这么想,“这个功【作者:唐霜】【转载请注明来源】能不错,我在MCP Bone上把它注册一【版权所有】唐霜 www.tangshuang.net【原创内容,转载请注明出处】下,调个API就能用它的功能了。”
本文作者:唐霜,转载请注明出处。著作权归作者所有,禁止商业用途转载。【原创内容,转载请注明出处】然而,当我们是一个LLM应用或Agent【作者:唐霜】本文作者:唐霜,转载请注明出处。的开发者,有着非常明确的概念的时候,我们【版权所有】唐霜 www.tangshuang.net未经授权,禁止复制转载。就需要更多。
【本文受版权保护】【本文受版权保护】本文版权归作者所有,未经授权不得转载。在上一篇文章中,我画了一张时序图,来阐述【未经授权禁止转载】【关注微信公众号:wwwtangshuangnet】在一次对话交互中,LLM应用或Agent原创内容,盗版必究。【本文首发于唐霜的博客】调MCP工具来回答用户,是怎样的一个流程【本文受版权保护】本文版权归作者所有,未经授权不得转载。:
原创内容,盗版必究。本文作者:唐霜,转载请注明出处。
通过这张图,我们可以看到,整个过程非常麻【版权所有,侵权必究】未经授权,禁止复制转载。烦,你的LLM应用层,需要做非常复杂的代【关注微信公众号:wwwtangshuangnet】【版权所有】唐霜 www.tangshuang.net码架构,才能在MCP生态中汲取少量营养。【作者:唐霜】未经授权,禁止复制转载。有没有办法简化这个过程呢?
本文版权归作者所有,未经授权不得转载。【关注微信公众号:wwwtangshua未经授权,禁止复制转载。原创内容,盗版必究。ngnet】【关注微信公众号:wwwtangshua【版权所有,侵权必究】【原创内容,转载请注明出处】ngnet】转载请注明出处:www.tangshua本文作者:唐霜,转载请注明出处。【版权所有】唐霜 www.tangshuang.netng.net我们如果现在把我们的角色做一个互换,我们【本文首发于唐霜的博客】本文版权归作者所有,未经授权不得转载。不要再把自己作为MCP的队友,而是站在调【版权所有】唐霜 www.tangshuang.net未经授权,禁止复制转载。用MCP服务的应用开发者的角度来看,我们本文版权归作者所有,未经授权不得转载。本文作者:唐霜,转载请注明出处。要在自己的LLM应用中调用工具。其实流程【原创内容,转载请注明出处】【未经授权禁止转载】是固定的,无论我们是否接入MCP生态,这【本文首发于唐霜的博客】原创内容,盗版必究。个流程都不变,这在openAI 2023【原创不易,请尊重版权】原创内容,盗版必究。年1月发布Function Callin【版权所有,侵权必究】本文版权归作者所有,未经授权不得转载。g功能时就固定了:
【本文首发于唐霜的博客】【转载请注明来源】本文作者:唐霜,转载请注明出处。
现在MCP的出现,并不影响这张图的调用过【本文受版权保护】未经授权,禁止复制转载。程。但是由于MCP协议的复杂性,导致对我著作权归作者所有,禁止商业用途转载。著作权归作者所有,禁止商业用途转载。们自己LLM应用的改动过大,带来的迭代风转载请注明出处:www.tangshuang.net【本文首发于唐霜的博客】险太大了。有没有一种过渡方案,已降低这种本文作者:唐霜,转载请注明出处。【未经授权禁止转载】风险吗?
转载请注明出处:www.tangshua原创内容,盗版必究。【未经授权禁止转载】ng.net【关注微信公众号:wwwtangshua【原创不易,请尊重版权】未经授权,禁止复制转载。ngnet】工具列表的构造
【转载请注明来源】【本文首发于唐霜的博客】通过MCP Bone可以做到。MCP B【关注微信公众号:wwwtangshuangnet】【版权所有,侵权必究】one做了一层适配,以适应大模型调用工具【版权所有,侵权必究】原创内容,盗版必究。的需求。让我们思考一下,我们在调用LLM【访问 www.tangshuang.net 获取更多精彩内容】【转载请注明来源】服务时,是如何传参的?没错,就是在参数中【转载请注明来源】【原创不易,请尊重版权】传入tools参数,让大模型返回被选中的工具及其实时参原创内容,盗版必究。转载请注明出处:www.tangshuang.net数。
对于MCP生态而言,这里的核心点就在于,著作权归作者所有,禁止商业用途转载。【版权所有,侵权必究】如何构建这个tools参数。如果要自己接入MCP生态,在完成M著作权归作者所有,禁止商业用途转载。【未经授权禁止转载】CP的基础设施建设后,通过遍历MCP S【关注微信公众号:wwwtangshuangnet】未经授权,禁止复制转载。erver,拿到inputSchema来【原创内容,转载请注明出处】本文作者:唐霜,转载请注明出处。构造tools是可行的,前提是整个MCP在你的LLM应本文版权归作者所有,未经授权不得转载。著作权归作者所有,禁止商业用途转载。用中跑起来。而如果基于MCP Bone则转载请注明出处:www.tangshuang.net转载请注明出处:www.tangshuang.net非常简单,通过一个http请求就可以立即未经授权,禁止复制转载。【作者:唐霜】拿到这个tools参数。
此外,部分模型并不支持function 【原创不易,请尊重版权】【访问 www.tangshuang.net 获取更多精彩内容】calling,例如我们的国产之光dee转载请注明出处:www.tangshuang.net【本文受版权保护】pseek-r1。针对这类模型,我们从C原创内容,盗版必究。未经授权,禁止复制转载。line中得到启发,通过将tools构建为prompt文本,直接通过prom【作者:唐霜】【转载请注明来源】pt的方式与大模型交流。在prompt中【访问 www.tangshuang.net 获取更多精彩内容】【关注微信公众号:wwwtangshuangnet】,我们强调了大模型的任务是按照特定规则返【作者:唐霜】【原创不易,请尊重版权】回选中的工具列表。MCP Bone提供了【作者:唐霜】著作权归作者所有,禁止商业用途转载。一个接口,返回构造好的prompt,这个著作权归作者所有,禁止商业用途转载。【本文首发于唐霜的博客】prompt完全仿照Cline的系统提示【作者:唐霜】本文版权归作者所有,未经授权不得转载。词编写,开发者通过这个接口拿到promp原创内容,盗版必究。转载请注明出处:www.tangshuang.nett之后,可以把它拼接到系统提示词,抑或用本文版权归作者所有,未经授权不得转载。本文版权归作者所有,未经授权不得转载。户提示词中。这样,即使不支持functi原创内容,盗版必究。【版权所有】唐霜 www.tangshuang.neton calling的大模型,也会遵照提转载请注明出处:www.tangshuang.net【访问 www.tangshuang.net 获取更多精彩内容】示词,返回特定格式的工具选取结果(文本)【版权所有】唐霜 www.tangshuang.net著作权归作者所有,禁止商业用途转载。。
工具调用的解析
【版权所有,侵权必究】转载请注明出处:www.tangshua本文作者:唐霜,转载请注明出处。【版权所有】唐霜 www.tangshuang.netng.net【版权所有,侵权必究】本文作者:唐霜,转载请注明出处。对于支持function calling【作者:唐霜】本文版权归作者所有,未经授权不得转载。的大模型,会在选择工具后,返回tool_本文版权归作者所有,未经授权不得转载。原创内容,盗版必究。calls字段来提供给LLM应用调用工具【版权所有】唐霜 www.tangshuang.net【版权所有,侵权必究】的信息,LLM应用拿到这个信息之后,在自【本文首发于唐霜的博客】【访问 www.tangshuang.net 获取更多精彩内容】己内部执行对应的逻辑,拿到工具调用的结果转载请注明出处:www.tangshuang.net【原创不易,请尊重版权】。
著作权归作者所有,禁止商业用途转载。【转载请注明来源】【本文首发于唐霜的博客】但是对于不支持function call【版权所有】唐霜 www.tangshuang.net【版权所有】唐霜 www.tangshuang.neting的大模型呢?上文提到,通过prom著作权归作者所有,禁止商业用途转载。【原创不易,请尊重版权】pt工程,我们可以让它们根据用户输入的内【原创不易,请尊重版权】【本文受版权保护】容进行工具选择,但是它只能返回文本格式,原创内容,盗版必究。原创内容,盗版必究。而且由于大模型并不完全遵照提示词格式,所【本文首发于唐霜的博客】【原创内容,转载请注明出处】以,我们需要从文本中提取出真正有价值的信【本文受版权保护】【版权所有】唐霜 www.tangshuang.net息。作为MCP Bone的用户,则可以通【版权所有】唐霜 www.tangshuang.net【关注微信公众号:wwwtangshuangnet】过SDK中提供的函数,从文本中解析出与f【未经授权禁止转载】【原创不易,请尊重版权】unction calling结果一致的转载请注明出处:www.tangshuang.net【作者:唐霜】tool_calls。
【转载请注明来源】【作者:唐霜】这也就意味着,无论你所使用的LLM是否支【版权所有】唐霜 www.tangshuang.net转载请注明出处:www.tangshuang.net持function calling,我们原创内容,盗版必究。原创内容,盗版必究。都可以得到相同的结果。这样,我们就达到了在模型与工具交互层面的统一。这个统一,弥补了MCP协议缺失的另一半原创内容,盗版必究。转载请注明出处:www.tangshuang.net。
本文作者:唐霜,转载请注明出处。【关注微信公众号:wwwtangshua【作者:唐霜】【作者:唐霜】ngnet】【版权所有】唐霜 www.tangshu著作权归作者所有,禁止商业用途转载。【版权所有,侵权必究】ang.net调用流程
转载请注明出处:www.tangshua【版权所有,侵权必究】【访问 www.tangshuang.net 获取更多精彩内容】ng.net【作者:唐霜】【版权所有,侵权必究】有了MCP Bone,我们在开发LLM应本文作者:唐霜,转载请注明出处。【版权所有】唐霜 www.tangshuang.net用时,就可以以统一的模式完成工具调用。具【版权所有,侵权必究】【访问 www.tangshuang.net 获取更多精彩内容】体流程如下:
未经授权,禁止复制转载。【原创不易,请尊重版权】【转载请注明来源】
通过MCP Bone,一方面屏蔽了MCP未经授权,禁止复制转载。转载请注明出处:www.tangshuang.net生态的复杂性,另一方面又统一了模型调用工【转载请注明来源】【未经授权禁止转载】具的交互模式。这使得LLM应用的开发可以【原创内容,转载请注明出处】【原创不易,请尊重版权】简化很多。
【访问 www.tangshuang.n【本文首发于唐霜的博客】本文版权归作者所有,未经授权不得转载。et 获取更多精彩内容】【本文首发于唐霜的博客】【本文首发于唐霜的博客】【原创内容,转载请注明出处】让工具成为空气,消失不见
“大模型调用工具”,本质上,这个说法是不【未经授权禁止转载】著作权归作者所有,禁止商业用途转载。对的,大模型并没有调用工具,而只是提供了本文作者:唐霜,转载请注明出处。本文版权归作者所有,未经授权不得转载。调用工具的参数,真正调用工具的,是LLM【访问 www.tangshuang.net 获取更多精彩内容】【原创不易,请尊重版权】上层应用。上层应用在从LLM获得调用工具【原创内容,转载请注明出处】【版权所有,侵权必究】参数之后,调用工具,然后还要把工具执行结【关注微信公众号:wwwtangshuangnet】【本文首发于唐霜的博客】果和原始的用户请求一并发给LLM,才能得【原创不易,请尊重版权】本文作者:唐霜,转载请注明出处。到最终回复给用户的completion。
著作权归作者所有,禁止商业用途转载。【原创内容,转载请注明出处】转载请注明出处:www.tangshua转载请注明出处:www.tangshuang.net【转载请注明来源】ng.net著作权归作者所有,禁止商业用途转载。可以看到,在这样的交互中,我们作为开发者著作权归作者所有,禁止商业用途转载。【本文首发于唐霜的博客】,需要在应用中调两次LLM。这其实是非常【本文受版权保护】【关注微信公众号:wwwtangshuangnet】别扭的。当我们需要一个结果时,作为聪明的【原创不易,请尊重版权】【作者:唐霜】大模型,为什么要调两次呢?这种别扭感,不【本文受版权保护】转载请注明出处:www.tangshuang.net仅在体验上损耗开发者的耐心,而且在实操中【原创不易,请尊重版权】著作权归作者所有,禁止商业用途转载。也确实非常容易搞错。
本文版权归作者所有,未经授权不得转载。本文版权归作者所有,未经授权不得转载。【本文受版权保护】【本文首发于唐霜的博客】既然如此,MCP Bone设计了一种模式【本文受版权保护】本文版权归作者所有,未经授权不得转载。,让开发者直接调用MCP Bone的co【原创内容,转载请注明出处】【版权所有】唐霜 www.tangshuang.netmpletion接口,就可以直接得到工具未经授权,禁止复制转载。本文作者:唐霜,转载请注明出处。执行后的总结结果,也就是将上面的3个步骤【版权所有】唐霜 www.tangshuang.net转载请注明出处:www.tangshuang.net,合并为1个步骤。完成这个合并之后,开发原创内容,盗版必究。本文作者:唐霜,转载请注明出处。者在调用API时,与之前调用大模型的co【作者:唐霜】本文版权归作者所有,未经授权不得转载。mpletion接口一摸一样,即一个co原创内容,盗版必究。转载请注明出处:www.tangshuang.netmpletion接口的调用,不需要考虑工【版权所有】唐霜 www.tangshuang.net【作者:唐霜】具调用,工具调用过程由接口自动完成,调用【本文首发于唐霜的博客】【本文首发于唐霜的博客】接口的开发直接拿到最终结果,而整个过程只本文版权归作者所有,未经授权不得转载。【版权所有】唐霜 www.tangshuang.net有一次交互。并且,我们可以认为,工具的选【转载请注明来源】原创内容,盗版必究。择和执行过程,与deepseek-r1等【原创内容,转载请注明出处】【本文首发于唐霜的博客】思考模型的thinking过程具有同等地转载请注明出处:www.tangshuang.net本文作者:唐霜,转载请注明出处。位,因此,我们可以把这个部分的内容,放开本文版权归作者所有,未经授权不得转载。【本文受版权保护】给用户看,但是是作为对话中的一个附属信息【原创不易,请尊重版权】本文作者:唐霜,转载请注明出处。。
【版权所有,侵权必究】本文作者:唐霜,转载请注明出处。【版权所有】唐霜 www.tangshu【原创内容,转载请注明出处】【访问 www.tangshuang.net 获取更多精彩内容】ang.net【本文受版权保护】这种模式适合Agent中调用,因为在Ag著作权归作者所有,禁止商业用途转载。转载请注明出处:www.tangshuang.netent中,我们提前规划好了任务及工具调用【本文首发于唐霜的博客】【原创内容,转载请注明出处】,在执行某次调用时,我们很明确这次调用要【未经授权禁止转载】【本文首发于唐霜的博客】使用工具。
本文作者:唐霜,转载请注明出处。【本文受版权保护】【本文受版权保护】本文版权归作者所有,未经授权不得转载。
而在普通LLM中,我们并不清楚用户的输入著作权归作者所有,禁止商业用途转载。【本文受版权保护】,是否需要调用工具才能完成,如果动态的去【版权所有,侵权必究】【原创内容,转载请注明出处】决定是否需要调用工具,又会损失性能。因此【版权所有,侵权必究】原创内容,盗版必究。,本模式的调用更适合Agent这种场景,【原创不易,请尊重版权】【转载请注明来源】具有特定适用性。
著作权归作者所有,禁止商业用途转载。【本文首发于唐霜的博客】原创内容,盗版必究。这种设计,是从开发者的调用角度出发,尽可【本文首发于唐霜的博客】【原创不易,请尊重版权】能的简化应用背后的逻辑。只有当这种调用逻本文版权归作者所有,未经授权不得转载。本文作者:唐霜,转载请注明出处。辑足够简单时,开发者们才无需因为MCP协【本文受版权保护】本文版权归作者所有,未经授权不得转载。议的复杂性而却步。
转载请注明出处:www.tangshua转载请注明出处:www.tangshuang.net本文作者:唐霜,转载请注明出处。ng.net著作权归作者所有,禁止商业用途转载。MCP工具“集装箱”和“呼叫转移中心”
基于MCP Bone有一些不错的场景可以转载请注明出处:www.tangshuang.net【版权所有,侵权必究】实现。我们在MCP Bone上创建多个实原创内容,盗版必究。【本文受版权保护】例,每个实例可以只注册关联的MCP Se【访问 www.tangshuang.net 获取更多精彩内容】【版权所有】唐霜 www.tangshuang.netrver,从而让一个MCP Bone实例原创内容,盗版必究。转载请注明出处:www.tangshuang.net可以完成一个垂直领域的任务。这就像一个个【未经授权禁止转载】原创内容,盗版必究。集装箱,可以帮助应用厂商建立集中的分区M【版权所有,侵权必究】【原创内容,转载请注明出处】CP Server管理模式。
本文版权归作者所有,未经授权不得转载。【未经授权禁止转载】原创内容,盗版必究。另一个场景则是通过MCP Bone集中管【原创内容,转载请注明出处】【原创不易,请尊重版权】理自己常用的MCP Server,在不同转载请注明出处:www.tangshuang.net【转载请注明来源】的客户端(如Cursor和Cline)中【原创不易,请尊重版权】本文作者:唐霜,转载请注明出处。,使用mcp-bone来共享相同的工具列转载请注明出处:www.tangshuang.net【版权所有】唐霜 www.tangshuang.net表,这样,我们可以避免在切换工具工作时,原创内容,盗版必究。本文版权归作者所有,未经授权不得转载。需要重新配置mcpServers。而当我【未经授权禁止转载】本文版权归作者所有,未经授权不得转载。们需要增删工具时,也只需要在MCP Bo【本文首发于唐霜的博客】【未经授权禁止转载】ne平台上处理即可。它就像呼叫转移中心,【作者:唐霜】【版权所有】唐霜 www.tangshuang.net把分散的MCP Server集中在一个地【本文首发于唐霜的博客】本文作者:唐霜,转载请注明出处。方管理,又再以一个单一MCP Serve未经授权,禁止复制转载。【本文受版权保护】r向客户端提供使用。
【原创内容,转载请注明出处】【原创内容,转载请注明出处】【作者:唐霜】
通过MCP Bone,在你的客户端软件中【关注微信公众号:wwwtangshuangnet】转载请注明出处:www.tangshuang.net,减少管理MCP Server的麻烦。当【本文受版权保护】原创内容,盗版必究。然,这仅限于需要远程调用工具的情况,对于【原创内容,转载请注明出处】【本文受版权保护】local MCP Server而言,本著作权归作者所有,禁止商业用途转载。原创内容,盗版必究。地安装调用执行性能必然好很多。
本文作者:唐霜,转载请注明出处。【未经授权禁止转载】【未经授权禁止转载】【转载请注明来源】通过mcp-bone这个包,普通用户也可本文作者:唐霜,转载请注明出处。【作者:唐霜】以无缝接入MCP世界,甚至再配合上MCP【版权所有】唐霜 www.tangshuang.net转载请注明出处:www.tangshuang.net Bone提供的MCP Server挑选【原创不易,请尊重版权】本文版权归作者所有,未经授权不得转载。功能(从内置了API Key的服务中直接【原创不易,请尊重版权】原创内容,盗版必究。使用)还可以省去了去各个平台申请API 【版权所有】唐霜 www.tangshuang.net【本文受版权保护】Key的麻烦。
【作者:唐霜】【本文首发于唐霜的博客】所有的这些,都是从简化开发流程和使用便捷本文作者:唐霜,转载请注明出处。【作者:唐霜】性的角度出发而设计的。
转载请注明出处:www.tangshua【作者:唐霜】本文作者:唐霜,转载请注明出处。ng.net本文版权归作者所有,未经授权不得转载。【关注微信公众号:wwwtangshua【版权所有】唐霜 www.tangshuang.net未经授权,禁止复制转载。ngnet】结语
本文详细介绍了我是如何完成MCP Bon【转载请注明来源】【转载请注明来源】e这个项目的。整个项目大概花费了4天时间【作者:唐霜】【本文首发于唐霜的博客】。通过这个项目,我掌握了在MCP生态上构【版权所有】唐霜 www.tangshuang.net【原创内容,转载请注明出处】建应用产品的整个路径,也可以由此类推阿里原创内容,盗版必究。未经授权,禁止复制转载。云、魔搭社区等上线的MCP平台背地里的技【关注微信公众号:wwwtangshuangnet】本文作者:唐霜,转载请注明出处。术实现。
【本文受版权保护】【原创不易,请尊重版权】作为AI领域应用层面的基础设施,MCP虽【本文受版权保护】【访问 www.tangshuang.net 获取更多精彩内容】然还存在诸多不足的地方,但是无疑给整个社【本文首发于唐霜的博客】转载请注明出处:www.tangshuang.net区带来了一些重要的启示。虽然我在上一篇文【作者:唐霜】【原创不易,请尊重版权】章中批评了MCP生态的乱象问题,但并不否转载请注明出处:www.tangshuang.net【原创内容,转载请注明出处】定其作为促进AI应用发展的一个分支方向。【原创不易,请尊重版权】本文版权归作者所有,未经授权不得转载。在我的其他文章中,你可以了解到我对Age转载请注明出处:www.tangshuang.net【本文受版权保护】nt领域发展的认知,虽然构建通用Agen本文作者:唐霜,转载请注明出处。【转载请注明来源】t从现在来看越来越不大可能实现,但是,我【关注微信公众号:wwwtangshuangnet】本文版权归作者所有,未经授权不得转载。会在下一篇文章中阐述“自举式Agent架【原创内容,转载请注明出处】【转载请注明来源】构”来聊一聊我对Agent开发的一些认识未经授权,禁止复制转载。转载请注明出处:www.tangshuang.net。
本文作者:唐霜,转载请注明出处。未经授权,禁止复制转载。【未经授权禁止转载】【版权所有】唐霜 www.tangshu【本文受版权保护】【本文受版权保护】ang.net如果你对MCP Bone,或者对MCP本【本文受版权保护】未经授权,禁止复制转载。身有什么看法或自己的见解,欢迎在下方留言【未经授权禁止转载】【原创内容,转载请注明出处】讨论。
转载请注明出处:www.tangshua本文作者:唐霜,转载请注明出处。【关注微信公众号:wwwtangshuangnet】ng.net【访问 www.tangshuang.n【版权所有,侵权必究】未经授权,禁止复制转载。et 获取更多精彩内容】【本文受版权保护】2025-04-29 3271


