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的实际应用~

相关推荐
葡萄城技术团队12 小时前
【突破 AI 执行瓶颈】Harness 工具集化身,SpreadJS 原子能力与 MCP 深度融合
人工智能
黎阳之光12 小时前
黎阳之光:视频孪生重构新能源智慧工地,打造大型风光基地数智化建设标杆
大数据·人工智能·物联网·安全·数字孪生
山西茄子12 小时前
DeepStream9.0 service-maker
人工智能·deepstream
人工智能AI技术12 小时前
失控AI代码问题丛生,Harness管控方案实战解析
人工智能
佳杰云星12 小时前
如何给大模型集群选“大脑”?智算调度与管理平台 10 维选型指南(附选型评分表)
人工智能·kubernetes·大模型·云计算·gpu·算力调度·智算中心
lilihuigz12 小时前
易服客工作室:WordPress 7.0 “Armstrong”发布
人工智能
卷帘依旧13 小时前
React Hook采用环形链表的原因
前端
美团技术团队13 小时前
美团跑腿 Skill:一句话,骑手来帮忙
人工智能
lichenyang45313 小时前
从 HarmonyOS AI 聊天模块理解工程化架构:MVVM、Controller、Provider、请求封装与 SSE
前端
卷帘依旧13 小时前
为什么React Hooks不能用在if/for等条件/循环语句中
前端