MCP(Model Context Protocol,模型上下文协议)介绍

1. 背景

随着大语言模型(LLM, Large Language Model)的应用越来越广泛,一个核心问题逐渐凸显:

  • 模型在对话或推理时,往往只能依赖有限上下文窗口
  • 外部工具、知识库、应用接口如何统一接入模型,缺乏标准协议。

为了解决这一问题,OpenAI 等社区提出了 MCP(Model Context Protocol),旨在建立一种通用的标准,让模型能够与外部数据源、工具和应用生态进行高效、安全、灵活的交互。


2. 什么是 MCP

MCP(Model Context Protocol)是一种 开放标准协议,用于定义模型与外部世界交互的方式。
它的目标是:

  • 为 LLM 提供 统一的上下文接口
  • 支持模型调用外部数据、API、工具。
  • 提高可扩展性和安全性,避免厂商锁定。

一句话理解:
👉 MCP 是大语言模型与外部系统之间的“标准通信协议”。


3. 核心功能

MCP 协议定义了模型与外部资源交互的基本方式,主要包括:

  1. 资源管理

    • 统一描述外部数据源(数据库、文件系统、知识库、API 等)。
    • 模型可以通过 MCP 请求这些资源的上下文。
  2. 工具调用(Tool Invocation)

    • 定义标准化的“工具调用”接口。
    • 不论是数据库查询、网络请求还是本地运算,模型都能通过相同方式访问。
  3. 上下文注入(Context Injection)

    • 自动将外部上下文注入模型对话。
    • 避免模型“遗忘”重要信息。
  4. 安全与可控性

    • 限制模型的调用权限。
    • 通过协议层做访问控制,防止越权。

4. MCP 的架构

MCP 通常由三部分组成:

  1. 模型(Model)

    • 负责语言理解与生成。
    • 通过 MCP 请求外部资源。
  2. 客户端(Client)

    • 作为桥梁,管理上下文。
    • 调度请求,保证安全。
  3. 服务端(Server, MCP Provider)

    • 提供资源和工具。
    • 可以是数据库、API、知识库或企业应用。

架构可以理解为:模型 ⇄ 客户端(MCP 协议)⇄ 外部系统


5. 应用场景

MCP 在实际应用中有非常广的潜力,例如:

  • 智能问答系统
    模型通过 MCP 从知识库获取信息,回答更准确。

  • 企业应用集成
    LLM 可以调用 ERP、CRM、数据库等系统。

  • 多模态扩展
    模型可以通过 MCP 接入图像识别、语音识别服务。

  • 个性化助手
    通过 MCP 访问用户日历、邮件、文档,提高智能性。


6. 总结

  • MCP(Model Context Protocol)是为了解决 LLM 上下文受限与外部系统接入难题 而提出的开放协议。
  • 它的核心作用是:标准化模型与外部数据/工具交互的方式
  • MCP 有望成为 AI 应用的基础标准,推动大模型与企业系统、知识库、工具的深度融合。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/news/920772.shtml
繁体地址,请注明出处:http://hk.pswp.cn/news/920772.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

synchronized的锁对象 和 wait,notify的调用者之间的关系

谁调用了wait和notify方法,会决定这两个方法的控制范围吗?你的问题非常深入,涉及到 wait() 和 notify() 方法的控制范围和作用域。让我们详细分析一下:✅ 核心概念:控制范围由“锁对象”决定wait() 和 notify() 的控制…

【技术教程】如何将文档编辑器集成到用 .Net 编写的网络应用程序中

在现代网络应用中,​富文本编辑能力已成为内容管理系统的核心需求。对于 .NET 开发者而言,选择适合的编辑器并高效集成,是构建企业级应用的关键一步,可让项目管理、 CRM 或定制化系统具备原生办公能力,消除频繁切换应用…

【大模型记忆-Mem0详解-1】概述

目的和能力 Mem0 通过提供以下功能将无状态 AI 应用程序转换为有状态、支持内存的系统: 持久记忆 :跨会话长期保留用户偏好、对话历史记录和上下文信息多级内存 :支持具有自适应个性化的用户级、会话级和代理级内存智能提取 :基于…

2024年山东省信息学小学组(CSP-X)第一轮题解

2024年山东省信息学小学组(CSP-X)第一轮题解 原题下载 单项选择题 阅读程序 阅读程序 #1 判断题 阅读程序 #2 判断题 单选题 阅读程序 #3 判断题 单选题 完善程序 消灭怪兽 位运算操作 原题下载 CSP-X2024小学组(山东)第一轮试题以及答案 单项选择题 共 15 题,每题 2 分…

SW - 用装配图的方式组合多个子零件然后转换成为零件,可维护性好

文章目录SW - 用装配图的方式组合多个子零件然后转换成为零件,可维护性好概述笔记例子将装配图另存为零件将零件图中的多个实体组合为一个实体的特征备注ENDSW - 用装配图的方式组合多个子零件然后转换成为零件,可维护性好 概述 以前画机械零件&#x…

PhotoshopImageGenerator:基于Photoshop的自动化图像数据集生成工具

整体逻辑与设计思路 PhotoshopImageGenerator是一个基于Python和Win32COM的自动化工具,通过控制Adobe Photoshop CC 2019创建多样化的图像数据集。其核心设计思路是通过程序化调用Photoshop的图像编辑能力,为基础图像添加随机元素(图片、文本、形状)和效果,快速生成大量变…

macos自动安装emsdk4.0.13脚本

1.替换文件 emsdk #!/bin/sh # Copyright 2019 The Emscripten Authors. All rights reserved. # Emscripten is available under two separate licenses, the MIT license and the # University of Illinois/NCSA Open Source License. Both these licenses can be # foun…

c++ Effective c++ 条款5

class MyClass { public:MyClass(int& ref, const int c_val) : myRef(ref), myConstVal(c_val) {}// 明确删除拷贝操作MyClass(const MyClass&) delete;MyClass& operator(const MyClass&) delete;private:int& myRef; // 引用成员const int myCo…

如何使用 Xshell 8 连接到一台 CentOS 7 电脑(服务器)

什么是 Xshell? Xshell 是一款功能强大的、适用于 Windows 平台的终端模拟器。它支持 SSH (Secure Shell)、SFTP、TELNET、RLOGIN 和 SERIAL 等多种网络协议,让用户能够安全地连接和管理远程服务器。 对于开发者、系统管理员和网络工程师来说&#xff…

CSS scale函数详解

目录 基本语法 核心特性 常用场景示例 1. 等比例缩放(X 轴和 Y 轴相同) 2. 非等比例缩放(X 轴和 Y 轴不同) 3. 翻转并缩放 4. 配合过渡动画实现交互效果 5. 图片悬停缩放效果 6. 缩放原点调整 与其他变换组合使用 注意…

【MATLAB代码】基于EKF的二维组合导航仿真代码,状态量为位置、速度、航向角与IMU偏置,观测量为XY轴的位置和速度,附完整代码

8维状态量(2维位置、2维速度、航向角、航向角偏置、2维加速度计偏置)+4维观测量(2维位置、2维速度)。 订阅专栏后,可直接查看源代码,粘贴到MATLAB空脚本中即可直接运行、得到结果 文章目录 运行结果 MATLAB源代码 程序详解 📘 程序概述 状态预测(状态转移函数) 状态雅…

OpenCV 图像轮廓检测

目录 一、轮廓检测基础概念 二、核心 API 详解:cv2.findContours () 参数说明: 返回值说明: 三、轮廓检测实战步骤 1. 图像预处理(灰度化与二值化) 2. 查找轮廓 3. 绘制轮廓 四、轮廓的常用属性与操作 1. 轮…

【图论】 Graph.jl 概览

文章目录安装基础使用基本操作全局图的指标顶点性质边性质读写图按照 .lgz 格式存储图数据(压缩格式)按照 .lg 格式存储图数据(非压缩格式)图的绘制TikzGraphs.jl Latex 论文风格GraphPlot.jl 通常与 Compose.jl 一起使用SGtSNEpi…

[java] 控制三个线程按顺序交替输出数字123123…

控制三个线程按顺序交替输出数字123123… synchronized(配合专用锁对象) 通过共享锁和 volatile 变量控制执行顺序,每个线程按指定顺序打印指定内容,确保输出序列如 “123123…”。使用 synchronized 和 wait/notifyAll 实现线程间…

[C#]winform基于yolov8-seg实现的指甲分割实现源码

【测试环境】 vs2019 net framework4.7.2 onnxruntime1.16.3 opencvsharp 注意源码运行在CPU上不支持GPU运行,由于net framework限制GPU会很慢因此没有GPU版本提供。 【运行步骤】 打开sln项目 选择x64 debug运行即可 如需要再x64 release运行可以将x64 debu…

数据结构——线性表(链表,力扣中等篇,增删查改)

文章目录一、增删查改1.1增(插入节点)1.1.1两数后插入公约数1.1.2循环有序链表的插入1.2删(移除节点)1.2.1删除已知的node节点【交换val值】1.2.2移除数组中已存在的节点【unordered_set】1.2.3删除和为0的节点【前缀和】1.3改&am…

【Android】OkHttp发起GET请求 POST请求

三三要成为安卓糕手 一:OkHttp介绍 OkHttp 是一个开源的、强大且高效的 HTTP 客户端库,主要用于在 Java后端和Android 项目中进行网络请求。 //在gradle中添加依赖 com.squareup.okhttp3:okhttp:4.12.0二:GET请求/*** 使用OkHttp发起get请求*…

[Mysql数据库] 知识点总结8

1. 请详细描述在复制拓扑中参与复制的线程类型以及各自所承担的功能。答:当从属服务器连接到主服务器时,在主服务器上会创建 Binlog 转储线程,在从属服务器上会默 认创建 I/O 线程和 SQL 线程。- Binlog 转储线程用于从二进制日志读取事件并将…

250829-Gitlab数据备份与恢复

下面给你一份可落地的迁移方案,保证 GitLab 的数据和配置完整迁移到服务器 B。你当前用的是 GitLab Omnibus(docker 版),数据都在你映射的 3 个目录里(/etc/gitlab, /var/log/gitlab, /var/opt/gitlab)&…

吴恩达机器学习作业十一:异常检测

数据集在作业一异常检测异常检测就是发现与大部分对象不同的对象,其实就是发现离群点。异常检测有时也称偏差检测。异常对象是相对罕见的。用数据集建立概率模型p ( x ),如果新的测试数据在这个模型上小于某个阈值,则说它极大可能为异常点算法…