当前位置: 首页 > article >正文

MCP技术体系介绍

MCP,全称时Model Context Protocol,模型上下文协议,由Claude母公司Anthropic于2014年11月正式提出。

MCP的核心作用是统一了Agent开发过程中大模型调用外部工具的技术实现流程,从而大幅提高Agent的开发效率。在MCP诞生之前,不同外部工具各有不同的调用方法。

 要连接这些外部工具,就必须一把锁配一把钥匙,开发过程相当繁琐。

而MCP的诞生则统一了这些外部工具的调用流程。使得无论是什么外部工具,都可以借助MCP技术按照统一的流程来快速接入到大模型中,从而大幅加快Agent开发效率。这叫好比现在很多设备都可以使用Type-C和电脑进行连接类似。而未来要做到这一点,MCP提供了三个方面的技术支持。第一是抽象的技术理论的支持,第二是一整套的MCP开发工具,也就是一些库,方便大家来进行MCP工具(MCP Server)的开发和智能体的构建。第三MCP还提供一整套非常丰富的开发生态。由于MCP是一套标准协议,任何MCP工具(MCP Server)都可以无缝接入到任何MCP智能体中。也就是你开发的工具我也能用,我开发的工具你也能用。目前开源社区上已经有上个个MCP工具了。如连接数据库工具、浏览器工具、网页搜索工具、文本编写提示词工具等等。而在MCP提携中,这些工具仅需要几行代码就可以嵌入到你的智能体中,从而低门槛大幅扩展当前智能体的能力边界。

MCP解决的最大痛点,就是Agent开发中调用外部工具的技术门槛过高的问题。

能调用外部工具,是大模型进化为智能体Agent的关键。如果不能使用外部工具。大模型就只能是个简单的聊天机器人。甚至连查询天气都做不到。由于底层技术限制,大模型本身是无法和外部工具直接通信的。因此Function Calling的思路,就是创建一个外部函数(function)作为中介,以变传递大模型的请求,另一边调用外部工具,最终让大模型能够间接调用外部工具。

 例如,当要查询当前天气时,让大模型调用外部工具的function calling的过程如下:

Function calling是个非常不错的技术设计。唯一的问题是,编写这个外部函数的工作量太大了。一个简单的外部函数往往需要上百行代码。而且为了让大模型认识这些外部函数,我们还需要额外为每个外部函数编写一个JSON Schema格式的功能说明,此外,我们还需要精心设计一个提示词模板,才能提高Function calling响应的准确率。

MCP的目标,就是在Agent开发过程中,让大模型更加便捷的调用外部工具。为此,MCP提出了两个方案。其一,统一function Calling的运行规范。

首先是统一名称,MCP把大模型运行环境称作MCP client.也就是MCP客户端,同时把MCP运行环境称作MCP Server。

然后统一MCP客户端和服务器的运行规范,并且要求MCP客户端和服务器之间,也统一按照某个既定的提示词模板进行通信。

这样好的好处在于可以避免MCP服务的重复开发,也就是避免外部函数的重复编写。例如像查询天气、网页爬取、查询本地MySQL数据库这种通用需求,大家有一个开发一个服务器就好,开发完大家都可以复制到自己的项目使用,不用每个人每次都单独写一套。

这极大的促进了全球AI开发者共同协作。目前GitHub上已经出现了海量的已经开发好的MCPServer,从SQL数据库检索到网页浏览信息爬取,从命令行操作电脑到数据分析机器学习建模等等不一而足。

现在只要你本地运行的大模型支持MCP协议,只需要安装相关的库,仅需几行代码就可以接入这些海量的外部工具。MCP协议的目的是希望通过提高协作效率来提升开发效率,例如http。

为了普及MCP协议,anthropic还提供了一整套MCP客户端、服务器端开发的SDK,并且支持python、TS和java等多种语言,借助SDK,仅需几行代码,就可以快速开发一个MCP服务器。

然后你就可以把它接入任意一个MCP客户端来构建智能体。如果愿意,还可以把MCP服务器分享到社区,给有需求的开发者使用,甚至你还可以把你的MCP服务器放到线上运行,让用户付费使用。

而MCP的客户端,不仅支持Claude模型(美国人工智能初创公司Anthropic发布的大型语言模型家族,拥有高级推理、视觉分析、代码生成、多语言处理、多模态等能力,该模型对标ChatGPT、Gemini等产品),也支持任意本地模型或者在线大模型,或者是一些IDE。例如,现在Cursor正式接入MCP,代表着Cursor正式成为MCP客户端,在Cursor中,我们不仅快速编写MCP Server。更能借助Cursor一键连接上成百上千的开源MCP服务器。让大模型快速接入海量工具,从而大幅加快Agent开发进度。

Function Calling技术回顾

大模型Agent开发体系

MCP的出现,主要是改进了Tools模块的实现方式。

MCP Client开发流程

uv入门介绍

     MCP开发要求借助uv进行虚拟环境创建和依赖管理。uv是一个python依赖管理工具,类似于pip 和 conda,但它更快、更高效,并且可以更好的管理python虚拟环境和依赖项。它的核心目标是替代pip、venv和pip-tools。提供更好的性能和更低的管理开销。

uv的特点:

  1. 一个单一的工具,以取代pip, pip-tools, pipx,诗歌,pyenv, twine, virtualenv,等等。
  2. 比pip快10-100倍。
  3. 提供全面的项目管理,具有通用的锁文件。
  4. 运行脚本,支持内联依赖元数据。
  5. 安装和管理Python版本。
  6. 运行和安装作为Python包发布的工具。
  7. 包括一个pip兼容的接口,用于使用熟悉的CLI提高性能。
  8. 支持可扩展项目的cargo风格工作区。
  9. 磁盘空间效率高,具有用于依赖性重复数据删除的
http://www.lryc.cn/news/2386100.html

相关文章:

  • 《深入探秘:从底层搭建Python微服务之FastAPI与Docker部署》
  • 深入解析Spring Boot与JUnit 5集成测试的最佳实践
  • 我的第1个爬虫程序——豆瓣Top250爬虫的详细步骤指南
  • Selenium 测试框架 - C#
  • JavaWeb:SpringBoot工作原理详解
  • 5.25本日总结
  • OpenGL Chan视频学习-6 How Shaders Work in OpenGL
  • dify_plugin数据库中的表总结
  • 【数据仓库面试题合集④】SQL 性能调优:面试高频场景 + 调优策略解析
  • HarmonyOS学习——UIAbility组件(上)
  • 【Linux】磁盘空间不足
  • 持续更新 ,GPT-4o 风格提示词案例大全!附使用方式
  • 线性代数之张量计算,支撑AI算法的数学原理
  • QStandardItemModel的函数和信号介绍
  • Python 内存管理机制详解:从分配到回收的全流程剖析
  • 【报错】Error attempting to get column ‘created_time‘ from result set.解决方法
  • Redis 3.0~8.0特性与数据结构全面解析
  • Google 推出 Flow —— AI 电影制作新平台
  • 跨链风云:打破区块链孤岛,实现价值自由流转
  • 鸿蒙开发:了解$$运算符
  • 基于CEEMDAN-Transformer-BiLSTM的多特征风速气候预测的完整实现方案及PyTorch源码解析
  • 特征预处理
  • 第七课 医学影像学临床研究数据管理与统计分析思路
  • 基于TypeScript的全栈待办事项应用Demo
  • obsidian 中的查找和替换插件,支持正则
  • 国际荐酒师(香港)协会亮相新西兰葡萄酒巡展深度参与赵凤仪大师班
  • 【深度学习】2. 从梯度推导到优化策略:反向传播与 SGD, Mini SGD
  • 工业软件国产化:构建自主创新生态,赋能制造强国建设
  • UART、RS232、RS485基础知识
  • AI重塑数据治理的底层逻辑