当前位置: 首页 > 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. 磁盘空间效率高,具有用于依赖性重复数据删除的

相关文章:

MCP技术体系介绍

MCP,全称时Model Context Protocol,模型上下文协议,由Claude母公司Anthropic于2014年11月正式提出。 MCP的核心作用是统一了Agent开发过程中大模型调用外部工具的技术实现流程,从而大幅提高Agent的开发效率。在MCP诞生之前,不同外部工具各有不同的调用方法。 要连接这些…...

《深入探秘:从底层搭建Python微服务之FastAPI与Docker部署》

FastAPI作为一款现代、快速的Web框架,在Python微服务开发领域独树一帜。它基于Python 3.6的类型提示功能,融合了Starlette和Pydantic的优势,具备诸多令人瞩目的特性。 FastAPI的性能表现十分卓越,可与Go和Node.js相媲美。这得益于…...

深入解析Spring Boot与JUnit 5集成测试的最佳实践

深入解析Spring Boot与JUnit 5集成测试的最佳实践 引言 在现代软件开发中,单元测试和集成测试是确保代码质量的重要手段。Spring Boot作为当前最流行的Java Web框架之一,提供了丰富的测试支持。而JUnit 5作为最新的JUnit版本,引入了许多新特…...

我的第1个爬虫程序——豆瓣Top250爬虫的详细步骤指南

我的第1个爬虫程序——豆瓣Top250爬虫的详细步骤指南 一、创建隔离开发环境 1. 使用虚拟环境(推荐venv) # 在项目目录打开终端执行 python -m venv douban_env # 创建虚拟环境 source douban_env/bin/activate # Linux/macOS激活 douban_env\Scri…...

Selenium 测试框架 - C#

🚀Selenium C# 自动化测试实战:以百度搜索为例 本文将通过一个简单示例,手把手教你如何使用 Selenium + C# 实现百度搜索自动化测试。适合初学者快速上手,也适合作为企业 UI 自动化测试模板参考。 🧩 一、安装必要 NuGet 包 在 Visual Studio 的 NuGet 管理器中安装以下…...

JavaWeb:SpringBoot工作原理详解

一、SpringBoot优点 1.为所有Spring开发者更快的入门 2.开箱即用,提供各种默认配置来简化项目配置 3.内嵌式容器简化Web项目 4.没有冗余代码生成和XML配置的要求 二、SpringBoot 运行原理 2.1. pom.xml spring-boot-dependencies: 核心依赖在父工程中;…...

5.25本日总结

一、英语 复习list6list25 二、数学 写14讲课后题,学习15讲部分 三、408 完成计网5.3题目,学习计组第二章 四、总结 今日所学内容不难,但是英语最近的进度缓慢,单词记忆情况不好,阅读也很久没有再写&#xff0c…...

OpenGL Chan视频学习-6 How Shaders Work in OpenGL

bilibili视频链接: 【最好的OpenGL教程之一】https://www.bilibili.com/video/BV1MJ411u7Bc?p5&vd_source44b77bde056381262ee55e448b9b1973 一、知识点整理 1.1 着色器 1.1.1 阐述 实际上是代码。需要告诉GPU发送数据要干啥,也是着色器的本质。…...

dify_plugin数据库中的表总结

本文使用dify-plugin-daemon v0.1.0版本,主要对dify_plugin数据库中的数据表进行了总结。 一.agent_strategy_installations 源码位置:dify-plugin-daemon\internal\types\models\agent.go type AgentStrategyInstallation struct {ModelTenantID …...

【数据仓库面试题合集④】SQL 性能调优:面试高频场景 + 调优策略解析

随着业务数据规模的持续增长,SQL 查询的执行效率直接影响到数据平台的稳定性与数据产出效率。因此,在数据仓库类岗位的面试中,SQL 性能调优常被作为重点考察内容。 本篇将围绕常见 SQL 调优问题,结合实际经验,整理出高频面试题与答题参考,助你在面试中游刃有余。 🎯 高…...

HarmonyOS学习——UIAbility组件(上)

UIAbility组件概述 应用程序有几种界面交互形式 UIAbility:应用程序的入口 概述 UIAbility组件是一种包含UI的应用组件,主要用于和用户交互。 UIAbility的设计理念: 原生支持应用组件级的跨端迁移和多端协同。 支持多设备和多窗口形态。…...

【Linux】磁盘空间不足

错误提示: no space left on device 经典版(block占用) 模拟 dd if/dev/zero of/var/log/nginx.log bs1M count2000排查 #1. df -h 查看哪里空间不足,哪个分区#2. du -sh详细查看目录所占空间 du -sh /* 排查占用空间大的目录 du -sh /var/* du…...

持续更新 ,GPT-4o 风格提示词案例大全!附使用方式

本文汇集了各类4o风格提示词的精选案例,从基础指令到复杂任务,从创意写作到专业领域,为您提供全方位的参考和灵感。我们将持续更新这份案例集,确保您始终能够获取最新、最有效的提示词技巧。 让我们一起探索如何通过精心设计的提…...

线性代数之张量计算,支撑AI算法的数学原理

目录 一、张量计算的数学本质 1、线性代数:张量的几何与代数性质 2、微积分:梯度与自动微分 3、优化理论:张量分解与正则化 4、张量计算的核心操作 二、张量计算在AI算法中的作用 1、数据表示与处理 2、神经网络的参数表示 3、梯度计算与优化 三、张量计算在AI中的…...

QStandardItemModel的函数和信号介绍

前言 Qt版本:6.8.0 QStandardItem函数介绍 函数 部分函数有不同的重载来适应不同的模型,例如appendrow 构造函数与析构函数 1. QStandardItemModel(QObject *parent nullptr) 说明:创建一个空的模型(0行0列)。参数: parent&…...

Python 内存管理机制详解:从分配到回收的全流程剖析

在 Python 编程中,开发者无需像 C/C 那样手动分配和释放内存,但这并不意味着内存管理与我们无关。了解 Python 内存管理机制,能帮助我们编写出更高效、稳定的代码。接下来,我们将深入剖析 Python 内存管理的各个环节,并…...

【报错】Error attempting to get column ‘created_time‘ from result set.解决方法

postman报错以下内容 {"code": "500","msg": "查询失败:Error attempting to get column created_time from result set. Cause: java.sql.SQLFeatureNotSupportedException\n; null; nested exception is java.sql.SQLFeatur…...

Redis 3.0~8.0特性与数据结构全面解析

目录 引言 第一部分:Redis版本演进与核心特性 Redis 3.0(2015年):分布式架构的里程碑 Redis 4.0(2017年):模块化与性能优化 Redis 5.0(2018年):流数据结构…...

Google 推出 Flow —— AI 电影制作新平台

这周, Google I/O 2025 大会上发布了一些重磅 AI 公告。 他们推出了全新的图像模型 Imagen 4,还发布了升级版视频生成器 Veo 3、升级版 Gemini Pro 模型,以及一系列其他令人印象深刻的更新。 但将所有这些生成式媒体工具整合在一起的,是他们称为 Flow 的平台。 什么是 F…...

跨链风云:打破区块链孤岛,实现价值自由流转

嘿,各位技术爱好者们!今天我们来聊一个区块链领域非常火热且至关重要的话题——跨链技术。你可能听说过,比如想把在波场(Tron)链上的USDT转移到以太坊(Ethereum)网络上,这个过程就涉…...

鸿蒙开发:了解$$运算符

前言 本文基于Api13 有这样一个需求,一个Text组件,一个TextInput组件,要求Text组件同步展示TextInput组件里的内容,也就是TextInput组件输入什么内容,就要在Text组件里展示什么内容,这个需求如何实现呢&…...

基于CEEMDAN-Transformer-BiLSTM的多特征风速气候预测的完整实现方案及PyTorch源码解析

基于CEEMDAN-Transformer-BiLSTM的多特征风速气候预测的完整实现方案及PyTorch源码解析 一、模型架构设计 1.1 整体框架 该模型采用三级架构设计(图1): CEEMDAN分解层:对非平稳风速序列进行自适应分解多模态特征融合模块&#…...

特征预处理

作为机器学习初学者,理解特征预处理就像学做菜前必须学会的"洗菜、切配、腌制"——它直接决定了最终模型的口感(性能)。我会用最生活化的比喻代码示例带你轻松掌握这个必备技能。 一、为什么要特征预处理? 原始数据的问…...

第七课 医学影像学临床研究数据管理与统计分析思路

引言 医学影像学作为现代医学的重要组成部分,在疾病诊断、治疗监测和预后评估中发挥着关键作用。随着影像技术的快速发展和临床研究需求的不断增长,如何有效管理和分析医学影像学研究数据已成为临床研究成功的关键因素。本文将系统介绍医学影像学临床研究中的数据管理流程、…...

基于TypeScript的全栈待办事项应用Demo

Demo地址:git clone https://gitcode.com/rmbnetlife/todo-app.git Todo List 应用 这是一个基于TypeScript的全栈待办事项应用,前端使用React,后端使用Node.js和Express。 项目概述 这个Todo List应用允许用户: 查看所有待办…...

obsidian 中的查找和替换插件,支持正则

最近用着 obsidian 时,发现想要在当前文档中 查找和替换 内容时,没有自动查找和替换的功能,去插件市场查找也没有发现好用的插件,那就自己写一个吧。 全程用的 AI 来写的,当然,我对 JS/CSS/TypeScript 等没…...

国际荐酒师(香港)协会亮相新西兰葡萄酒巡展深度参与赵凤仪大师班

国际荐酒师(香港)协会率团亮相2025新西兰葡萄酒巡展 深度参与赵凤仪MW“百年百碧祺”大师班 广州/上海/青岛,2025年5月12-16日——国际荐酒师(香港)协会(IRWA)近日率专业代表团出席“纯净独特&…...

【深度学习】2. 从梯度推导到优化策略:反向传播与 SGD, Mini SGD

反向传播算法详解 1. 前向传播与输出层误差定义 假设我们考虑一个典型的前馈神经网络,其最后一层为 softmax 分类器,损失函数为交叉熵。 前向传播过程 对于某一隐藏层神经元 j j j: 输入: x i x_i xi​ 权重: w j…...

工业软件国产化:构建自主创新生态,赋能制造强国建设

随着全球产业环境的变化和技术的发展,建立自主可控的工业体系成为我国工业转型升级、走新型工业化道路、推动国家制造业竞争水平提升的重要抓手。 市场倒逼与政策护航,国产化进程双轮驱动 据中商产业研究院预测,2025年中国工业软件市场规模…...

UART、RS232、RS485基础知识

一、UART串口通信介绍 UART是一种采用异步串行、全双工通信方式的通用异步收发传输器功能。 硬件电路: •简单双向串口通信有两根通信线(发送端TX和接收端RX) •TX与RX要交叉连接 •当只需单向的数据传输时,可以只接一根通信线…...