MCP到底是什么

Hello 大家好,我是程序员Knight,最近MCP协议变得火热,公司中也在互相讨论,那么MCP究竟是什么呢?我们该如何使用MCP呢?接下来就让我们一探究竟。

MCP是什么?

MCP(Model Context Protocol, 模型上下文协议)是由人工智能公司(Anthropic)提出并开源的一种标准化通信协议,它主要用来解决AI模型与外部数据源、工具以及系统之间的连接问题。如果我们从OSI模型来看MCP的话,MCP处于OSI的应用层,其通过JSON-RPC的消息进行交互、会话管理、数据查询)。其对应OSI模型如下:

javascript 复制代码
OSI模型层级       MCP相关协议/组件
------------------------------------------------------------------------------------------------------------------
应用层         MCP协议(JSON-RPC)、HTTP、SSE
表示层         JSON数据格式编码
会话层         Mcp-Session-Id(会话管理)
传输层         TCP(远程通信场景)
网络层         IP
数据链路层     以太网/Wi-Fi
物理层         光纤/电缆等

在有了MCP的基础了解后,让我们再一起看看MCP的核心架构: MCP主要由三个核心组件构成:

  • MCP主机:发起请求的应用程序,负责向MCP客户端发送指令,例如大模型应用、VScode插件(Cline)
  • MCP客户端:作为中间桥梁,转发请求到MCP服务端并返回响应。
  • MCP服务端:轻量服务器,标准化功能结构,具备本地/云端的调用与部署。 架构图如下:

传输层(Transport Layer):处理真实请求。

  1. 本地请求:Stdio transport:
    • 通过标准 stdInput/stdOutput 来沟通
    • 适用于本地进程通信
  2. 远端请求,分为两种情况:
    • 客户端到服务端(Client to Server):通过HTTP Post请求
    • 服务端到客户端(Server to Client):通过服务端事件(Server-Sent Events) 所有的通信机制都基于JSON-RPC 2.0来通信,消息体采用UTF-8编码格式,确保跨平台的兼容性。

MCP的使用

在MCP介绍的官网上提供了不同语言的SDK用来集成现有的服务器,并且提供客户端与服务端的例子,我在之后也会出一篇专题文章来详细探索MCP的服务应用。在本篇中,我先着重介绍下,如何通过VSCode插件Cline与MCP来提高效率。

  1. 首先我们打开VSCode下载Cline,Cline是一个编辑器的AI助手,
  2. 打开Cline MCP控制台
  3. 添加MCP服务器,在Github仓库中我们可以找到现在已有的MCP服务器, 本次教程讲使用最火热的github
  4. 接下来我们根据其提供的下载方式进行在Cline中的配置。(采用 npx的方式)
  1. 接下来我们可以在 cline 对话框中以文本语言的方式来进行想要做的操作,如果有对应MCP服务器,会直接使用对应的工具来帮助我们完成操作。比如查找我当前所有的仓库指令:

希望读完这篇文章,能帮助你更好的理解MCP的作用,我在之后也会花时间来研究更多的MCP用处,在Github仓库中有更多提升效率的服务器。以后也让我们一起探索MCP的实际应用~

相关推荐
EulerBlind4 分钟前
【LLM】解锁Agent协作:深入了解谷歌 A2A 协议与 Python 实现
人工智能·python·语言模型
浔川python社5 分钟前
DeepSeek AI大模型:中国智能时代的“争气机“-AI生成
人工智能
电子连接器CAE与高频分析8 分钟前
MATLAB求和∑怎么用?
人工智能·算法·matlab
黑马王子139 分钟前
React JSX(二)
前端
eason_fan9 分钟前
如何实现一个VSCode插件(Cygwin Terminal 插件实践)
前端·visual studio code
好青崧10 分钟前
三级联动制作总结
前端·javascript
Dignity_呱11 分钟前
大厂在用的css+js实现不等高瀑布流布局
前端·vue.js·面试
磊叔的技术博客14 分钟前
A2A 与 MCP:智能体协作的新纪元与AI工程化的思考
人工智能·开源·mcp
Sky重名了10494815 分钟前
npm link 使用指南
前端·npm
熊猫片沃子17 分钟前
使用nvm解决nodejs多版本问题,难道不香吗?
前端·npm·node.js