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

MCP (Model Context Protocol) 技术理解 - 第一篇


文章目录

  • 引言
  • MCP是什么
  • MCP到底解决什么问题?
  • MCP的架构
  • 小结

引言

我一直为网上没有很好且通俗易懂的MCP技术文档而烦恼,所以我通过记录自己查阅官方文档来写一份通俗易懂的MCP技术文档,从架构到实战,既有技术深度,又能让小白一听就懂。这对我是一种挑战,如果笔误可以在评论区指出,谢谢!

MCP是什么

Model Context Protocol (MCP) 是 Anthropic 于 2024 年 11 月发布的开放标准协议,旨在为 LLM 应用提供统一的方式来连接外部数据源和工具。它被称为"AI 的 type-c接口"。

但是我觉得如果就将它比喻成type-c接口,我觉得太草率。

我们先标出重点,MCP它是一种协议,一种标准!MCP是一种协议,MCP是一种协议,MCP是一种协议,重要的事情说三遍。

那么它到底是干了什么?这里直接通俗易懂来说吧,假如说LLM是大脑,那么LLM可以通过MCP协议长出手脚,可以做到访问资源,调用工具,预制模板的事情等。

为什么这么说?在古早时期,也就是Chat-GPT横空出世的时候,他也就是一个简单的chatbot,靠着以往的知识库回答问题,而不能实时去访问web上的资源和你自己的知识库,也不能去帮你发邮件,订航班等等。有了MCP,我们就有了一种标准去做这些事。我们只要去实现了标准MCP的接口,数据发送和接收都是解析相同格式的数据,那么按照理论来说,我们就能让AI应用帮我们做任何事情(当前不讨论物理世界的劳动)。

MCP到底解决什么问题?

我们上面讨论了MCP能帮我们实现的事情,那么MCP它本质上到底解决了什么问题?难道我们以前没有MCP就无法查看web上面的资源或者知识库吗?让我们下面一起讨论一下。

传统上,我们也是可以实现MCP的功能,但是这样有个问题,每个企业所创造出来的软件或者说应用程序,它都不是一个统一的接口来进行tool calling的,都是自成一派。这样就会导致集成非常繁杂。

上代码来解释一下这种现象?

传统方式的痛点:

# 每个集成都需要自定义代码ifservice=="github":github_client=GitHubClient(token)data=github_client.get_issues()elifservice=="slack":slack_client=SlackClient(token)data=slack_client.get_messages()elifservice=="database":db_client=DatabaseClient(connection_string)data=db_client.query("SELECT * FROM users")# ... 每个服务都不同

使用MCP统一了之后:

# 统一接口,标准化协议mcp_client=McpClient()# 所有服务使用相同的协议resources=mcp_client.list_resources()# 获取可用资源tools=mcp_client.list_tools()# 获取可用工具result=mcp_client.call_tool("search",args)# 调用工具

这里我们强调一下MCP的三大核心能力吧,分别是访问资源,调用工具,预制模板,下面的表格解释了它各自的特点与作用

能力说明控制方示例
Resources只读数据源Application文件内容、数据库记录、API 响应
Tools可执行函数Model搜索航班、发送消息、创建日历事件
Prompts预制模板User计划旅行、总结会议、起草邮件

理解三大能力是非常重要的,关乎MCP的开发能力。

MCP的架构

现在我们一起来看看MCP的架构是怎么样的。

MCP 采用客户端-服务器架构,其中 MCP 主机(例如Claude Code或Claude Desktop等 AI 应用)与一个或多个 MCP 服务器建立连接。MCP 主机通过为每个 MCP 服务器创建一个 MCP 客户端来实现这一点。每个 MCP 客户端与其对应的 MCP 服务器保持专用连接。使用 STDIO 传输的本地 MCP 服务器通常服务于单个 MCP 客户端,而使用 Streamable HTTP 传输的远程 MCP 服务器通常服务于多个 MCP 客户端。MCP架构的关键参与者包括:

  • MCP 主机:用于协调和管理一个或多个 MCP 客户端的 AI 应用程序
  • MCP 客户端:一个维护与 MCP 服务器连接并从 MCP 服务器获取上下文以供 MCP 主机使用的组件。
  • MCP 服务器:一个为 MCP 客户端提供上下文信息的程序

这里引用官方文档的例子:

例如:Visual Studio Code 充当 MCP 主机。当 Visual Studio Code 与 MCP 服务器(例如Sentry MCP 服务器)建立连接时,Visual Studio Code 运行时会实例化一个 MCP 客户端对象来维护与 Sentry MCP 服务器的连接。随后,当 Visual Studio Code 连接到另一个 MCP 服务器(例如本地文件系统服务器)时,Visual Studio Code 运行时会实例化另一个 MCP 客户端对象来维护此连接。

请注意,MCP 服务器指的是提供上下文数据的程序,无论其运行位置如何。MCP 服务器可以本地运行,也可以远程运行。例如,当 Claude Desktop 启动文件系统服务器时,由于它使用 STDIO 传输,因此服务器运行在同一台机器上。这通常被称为“本地”MCP 服务器。官方的 Sentry MCP 服务器运行在 Sentry 平台上,并使用 Streamable HTTP 传输。这通常被称为“远程”MCP 服务器。

小结

第一篇我们就先解析MCP的概念,解决的问题,还有架构。接下来我们继续解析通信协议和数据格式等,有兴趣的可以关注此栏目

http://www.jsqmd.com/news/360125/

相关文章:

  • 2026年靠谱的三合一设备/不锈钢三合一设备厂家采购参考指南 - 品牌宣传支持者
  • 2026年口碑好的精密吹塑/异形吹塑厂家口碑推荐汇总 - 品牌宣传支持者
  • IT运维智能体开发工程师的技术全景与实践指南
  • 协鑫集成高级AI开发工程师职位深度解析:职责、能力与面试指南
  • 安卓驱动开发工程师:深入技术核心,驱动智能未来
  • 2026年知名的澳洲移民留学对接/澳洲移民签证办理口碑排行实力厂家口碑参考 - 品牌宣传支持者
  • 2026年热门的氢氟酸反应釜/磷酸反应釜厂家采购参考指南(必看) - 品牌宣传支持者
  • 2026年热门的搪瓷薄膜蒸发器/山东刮板式薄膜蒸发器厂家最新推荐 - 品牌宣传支持者
  • 3DE CATIA基于知识工程的高效设计实战!
  • 聊一下电磁仿真和常用的电磁仿真软件
  • 2026年评价高的搪玻璃薄膜蒸发器/山东搪玻璃厂家实力参考 - 品牌宣传支持者
  • 2026年靠谱的丝绒压光压花/面料凹凸压光压花行业内口碑厂家推荐 - 品牌宣传支持者
  • 人工智能开发职位申请指南:陕西华码半导体科技有限公司面试准备
  • 南京夏宏智能科技有限公司人工智能工程师职位深度解析:技术精要、面试宝典与职业发展蓝图
  • 移动端软件开发工程师职位深度解析:以通桥医疗科技为例
  • 障碍期权做市商定价与对冲系统
  • 字符串 / 内存函数与大小端模式深度解析
  • PAC 分流配置文件使用指南
  • EasyX:从入门到入土
  • C# Avalonia 19- DataBinding- DataTemplateControls
  • viepress:vue组件展示和源码功能
  • 向阳花木(二)C++ ATTR 宏自动属性生成器——封装配置项
  • Snapd和Apt—Linux 上两种完全不同的软件包管理系统
  • 什么是网络数字地图
  • 基于Spring Boot的电子政务服务管理系统
  • 基于Spring Boot的躲猫猫书店管理系统
  • 从草稿到佳作:DeepSeek辅助学术论文写作的全流程技术指南
  • 【论文阅读:TPAMI_2025 基于对抗特征提取和稳定图像重建的红外与可见光图像融合】
  • 人该怎样活着呢?版本68.8
  • 2026年管桁架厂家厂家权威推荐榜:四川钢网架加工、屋顶钢结构网架、管桁架加工、管桁架批发、管桁架生产公司选择指南 - 优质品牌商家