MCP到底是什么

365 阅读3分钟

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

MCP是什么?

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

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

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

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

传输层(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助手, stepOne.png
  2. 打开Cline MCP控制台 MCP控制台.png
  3. 添加MCP服务器,在Github仓库中我们可以找到现在已有的MCP服务器, 本次教程讲使用最火热的github
  4. 接下来我们根据其提供的下载方式进行在Cline中的配置。(采用 npx的方式) download.png

config.png

MCPConfig.png

  1. 接下来我们可以在 cline 对话框中以文本语言的方式来进行想要做的操作,如果有对应MCP服务器,会直接使用对应的工具来帮助我们完成操作。比如查找我当前所有的仓库指令:

MCPUsage.png

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