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

一文了解 MCP Server:AI 工具与外部世界的桥梁

引言

        随着大语言模型(LLM)的普及与 AI Agent 的爆发,Anthropic 于 2024 年底提出并开源的 Model Context Protocol(MCP,模型上下文协议)成为构建智能体系统的关键基石之一。本文将结合最新的实战经验(如 DeepSeek 技术社区、Cursor、ollama、vLLM、OpenAI 接入)为你全面讲解 MCP Server 的原理、开发流程、架构设计与实用价值。


一、MCP 是什么?为什么这么重要?

        MCP(Model Context Protocol)是为了解决“大模型无法访问外部工具与数据”的问题而设计的标准化通信协议。它的使命就像 USB-C —— 建立统一接口,让模型方便、安全、高效地调用各种外部能力(如:本地文件、数据库、API、工具等)。

MCP 的核心组成:

  • Model:语言模型(如 GPT、Claude、DeepSeek)

  • Context:上下文资源(如数据、文档、代码等)

  • Protocol:通信标准(基于 JSON-RPC 2.0)

为什么 MCP 比 Function Calling 更重要?

传统的 Function Calling 存在以下问题:

  • 每个函数都要手工实现,重复造轮子

  • JSON Schema 写法复杂繁琐

  • 没有统一协议,互通性差

而 MCP:

  • 定义了统一的 Client 和 Server 规范(“车同轨,书同文”)

  • 社区已有上千个开源 MCP Server,可直接复用

  • 与主流 IDE(Cursor)、模型框架(vLLM、DeepSeek)兼容


二、MCP Server 是什么?能做什么?

MCP Server 是遵循 MCP 协议的服务端,能为模型暴露:

功能类型说明示例
Resources提供资源,如文件、数据库、API 内容读取文本、加载数据库记录
Tools可执行函数或外部工具调用发起 HTTP 请求、发 PR、执行命令
Prompts预定义提示词模板自动补全代码片段、生成摘要

通信方式:

  • 本地(Stdio):客户端以子进程形式调用 Server,使用标准输入输出通信

  • 远程(HTTP + SSE):使用 EventSource 实时推送消息(计划未来支持 Streaming HTTP)


三、MCP Server 架构图解

+--------------------------+           +-----------------------------+
|        MCP Client        | <-------> |        MCP Server           |
|  (如 Claude Desktop)     |           |  (如 本地 MySQL 工具)       |
+--------------------------+           +-----------------------------+^     |                                     ||     | JSON-RPC 调用                     注册 Tools/Resources|     v
+-----------------------------------------------+
|      LLM (GPT、DeepSeek、vLLM等)               |
+-----------------------------------------------+


四、实战:快速开发 MCP Server

1. 使用 Python 快速构建 MCP 工具服务

以查询天气为例:

from mcp.server.fastmcp import FastMCP
import httpxmcp = FastMCP("WeatherServer")@mcp.tool()
async def query_weather(city: str) -> str:resp = await httpx.get(f"https://api.openweathermap.org/data/2.5/weather?q={city}&appid=YOUR_API_KEY")return resp.textif __name__ == "__main__":mcp.run(transport="stdio")

2. 用命令行方式运行 MCP Server

python weather_server.py

或者让 MCP Client 以子进程方式启动它。

3. MCP Client 调用示例(支持本地模型)

from mcp.client.stdio import stdio_client
from mcp import ClientSessionsession = await ClientSession.from_stdio("python", ["weather_server.py"])
await session.initialize()
result = await session.call_tool("query_weather", {"city": "Beijing"})
print(result)


五、MCP Server 实用案例

类型工具名称功能
浏览器自动化puppeteer / playwright自动化打开网页、点击元素、截图
Git 操作git-mcp-server发起 PR、git commit、分支合并
文件操作file-server读写本地文件、列出目录
MySQL 连接mysql-mcp自然语言执行 SQL 查询
命令执行shell-mcp运行 shell 命令并返回结果

资源集合:

  • https://mcp.so

  • https://github.com/modelcontextprotocol/servers

  • https://github.com/punkpeye/awesome-mcp-servers


六、进阶指南

1. 接入本地 LLM(如 ollama、vLLM、DeepSeek)

  • MCP Client 使用 OpenAI SDK 风格接口

  • 设置 .env 文件:

BASE_URL=http://localhost:11434/v1
MODEL=deepseek-chat
OPENAI_API_KEY=ollama
  • 启动命令:

uv run client.py server.py

2. 可视化调试工具 MCP Inspector

npx -y @modelcontextprotocol/inspector uv run server.py
  • 浏览器访问:http://127.0.0.1:5173

用于实时查看 MCP Server 注册的资源、函数和响应结果。


七、总结:MCP 是未来 Agent 世界的“USB-C”

  • MCP 是统一大模型与外部工具交互的通用协议

  • MCP Server 是你构建智能体最重要的“外挂工具”集合

  • 借助 MCP Inspector、现成 MCP Server 仓库、主流 SDK(Python、Node)可以快速接入与开发

  • DeepSeek、Cursor、Claude 等主流平台全面支持 MCP,让 Agent 构建进入标准化时代

        MCP 不是新技术,而是一种“标准 + 工具”的革命。它正在推动 AI 工具从“孤岛”走向生态协作,人人都能成为“Agent 工程师”。

        如果你想真正掌握下一代 AI 应用的开发模式,MCP 是你绕不开的必修课。

相关文章:

一文了解 MCP Server:AI 工具与外部世界的桥梁

引言 随着大语言模型&#xff08;LLM&#xff09;的普及与 AI Agent 的爆发&#xff0c;Anthropic 于 2024 年底提出并开源的 Model Context Protocol&#xff08;MCP&#xff0c;模型上下文协议&#xff09;成为构建智能体系统的关键基石之一。本文将结合最新的实战经验&#…...

【redis】集群 数据分片算法:哈希求余、一致性哈希、哈希槽分区算法

文章目录 什么是集群数据分片算法哈希求余分片搬运 一致性哈希扩容 哈希槽分区算法扩容相关问题 什么是集群 广义的集群&#xff0c;只要你是多个机器&#xff0c;构成了分布式系统&#xff0c;都可以称为是一个“集群” 前面的“主从结构”和“哨兵模式”可以称为是“广义的…...

基于Springboot的网上订餐系统 【源码】+【PPT】+【开题报告】+【论文】

网上订餐系统是一个基于Java语言和Spring Boot框架开发的Web应用&#xff0c;旨在为用户和管理员提供一个便捷的订餐平台。该系统通过简化餐饮订购和管理流程&#xff0c;为用户提供快速、高效的在线订餐体验&#xff0c;同时也为管理员提供完善的后台管理功能&#xff0c;帮助…...

Redis常见面试问题汇总

Redis 面试笔记整理 一、Redis 基础知识1. Redis 概述Redis 是什么&#xff1f;主要特点有哪些&#xff1f;Redis 和 Memcached 的区别是什么&#xff1f;Redis 是单线程还是多线程&#xff1f;为什么单线程还能高效&#xff1f;Redis 6.0 之后的多线程模型是怎样的&#xff1f…...

【redis】集群 如何搭建集群详解

文章目录 集群搭建1. 创建目录和配置2. 编写 docker-compose.yml完整配置文件 3. 启动容器4. 构建集群超时 集群搭建 基于 docker 在我们云服务器上搭建出一个 redis 集群出来 当前节点&#xff0c;主要是因为我们只有一个云服务器&#xff0c;搞分布式系统&#xff0c;就比较…...

NLP高频面试题(二十)——flash attention原理

FlashAttention是一种针对Transformer模型中自注意力机制的优化算法&#xff0c;旨在提高计算效率并降低内存占用&#xff0c;特别适用于处理长序列任务。 在Transformer架构中&#xff0c;自注意力机制的计算复杂度和内存需求随着序列长度的平方增长。这意味着当处理较长序列时…...

飞牛NAS本地部署小雅Alist结合内网穿透实现跨地域远程在线访问观影

文章目录 前言1. VMware安装飞牛云&#xff08;fnOS&#xff09;1.1 打开VMware创建虚拟机1.3 初始化系统 2. 飞牛云搭建小雅Alist3. 公网远程访问小雅Alist3.1 安装Cpolar内网穿透3.2 创建远程连接公网地址 4. 固定Alist小雅公网地址 前言 嘿&#xff0c;小伙伴们&#xff0c…...

Episode, time step, batch, epoch

1. Episode&#xff08;回合&#xff09; 回合&#xff08;episode&#xff09;表示智能体从开始执行任务到完成任务&#xff08;例如成功到达目标或触发失败条件&#xff09;的全过程。 例如&#xff0c;如果我们训练一个四足机器人走到一个目标点&#xff0c;一个回合就是从…...

Linux版本控制器Git【Ubuntu系统】

文章目录 **前言**一、版本控制器二、Git 简史三、安装 Git四、 在 Gitee/Github 创建项目五、三板斧1、git add 命令2、git commit 命令3、git push 命令 六、其他1、git pull 命令2、git log 命令3、git reflog 命令4、git stash 命令 七、.ignore 文件1、为什么使用 .gitign…...

browser-use 库网页元素点击测试工具

目录 代码代码解释输出结果 代码 import asyncio import jsonfrom browser_use.browser.browser import Browser, BrowserConfig from browser_use.dom.views import DOMBaseNode, DOMElementNode, DOMTextNode from browser_use.utils import time_execution_syncclass Eleme…...

Vue 中使用 ECharts

在 Vue 中使用 ECharts 主要分为以下步骤&#xff0c;结合代码示例详细说明&#xff1a; 1. 安装 ECharts 通过 npm 或 yarn 安装 ECharts&#xff1a; npm install echarts --save # 或 yarn add echarts2. 基础使用&#xff08;完整引入&#xff09; 在 Vue 组件中使用 &…...

Spring AI + DeepSeek 构建大模型应用 Demo

Spring AI + DeepSeek 构建大模型应用 Demo 下面我将展示如何使用 Spring AI 框架结合 DeepSeek 的大模型能力构建一个简单的 AI 应用。 1. 环境准备 首先确保你已安装: JDK 17+Maven 3.6+Spring Boot 3.2+2. 创建 Spring Boot 项目 使用 Spring Initializr 创建项目,添加…...

解决GitLab无法拉取项目

1、验证 SSH 密钥是否已生成 ls ~/.ssh/ 如果看到类似 id_rsa 和 id_rsa.pub 的文件&#xff0c;则说明已存在 SSH 密钥。 避免麻烦&#xff0c;铲掉重来最方便。 如果没有&#xff0c;请生成新的 SSH 密钥&#xff1a; ssh-keygen -t rsa -b 4096 -C "your_emailexam…...

POSIX 线程取消与资源清理完全指南

POSIX 线程取消与资源清理完全指南 引言&#xff1a;为什么需要线程取消机制&#xff1f; 在多线程编程中&#xff0c;优雅地终止线程并确保资源释放是开发者面临的重要挑战。直接终止线程可能导致内存泄漏、文件未关闭等问题。POSIX 线程库提供了一套完整的线程取消和清理机…...

FPGA学习篇——Verilog学习之寄存器的实现

1 寄存器理论 这里在常见的寄存器种加了一个复位信号sys_rst_n。&#xff08;_n后缀表示复位信号低电平有效&#xff0c;无这个后缀的则表示高电平有效&#xff09; 这里规定在时钟的上升沿有效&#xff0c;只有当时钟的上升沿来临时&#xff0c;输出out 才会改变&#xff0c;…...

Cursor异常问题全解析-无限使用

title: Cursor异常问题全解析无限使用 tags: cursor categories:aiai编程 mathjax: true description: Cursor异常问题全解析与解决方案大全 abbrlink: 64908bd0 date: 2025-03-19 14:48:32 &#x1f916; Assistant &#x1f6a8; Cursor异常问题全解析与解决方案大全 &…...

【VUE】ant design vue实现表格table上下拖拽排序

适合版本&#xff1a;ant design vue 1.7.8 实现效果&#xff1a; 代码&#xff1a; <template><div class"table-container"><a-table:columns"columns":dataSource"tableData":rowKey"record > record.id":row…...

Vue实现动态数据透视表(交叉表)

需求:需要根据前端选择的横维度、竖维度、值去生成一个动态的表格&#xff0c;然后把交叉的值放入到对应的横维度和竖维度之下&#xff0c;其实就是excel里面的数据透视表功能&#xff0c;查询交叉语句为sql语句。 实现页面&#xff1a; 选择一下横维度、竖维度、值之后点击查…...

推荐《人工智能算法》卷1、卷2和卷3 合集3本书(附pdf电子书下载)

今天&#xff0c;咱们就一同深入探讨人工智能算法的卷1、卷2和卷3&#xff0c;看看它们各自蕴含着怎样的奥秘&#xff0c;并且附上各自的pdf电子版免费下载地址。 《人工智能算法&#xff08;卷1&#xff09;&#xff1a;基础算法》 下载地址&#xff1a;https://www.panziye…...

元宇宙浪潮下,数字孪生如何“乘风破浪”?

在当今科技飞速发展的时代&#xff0c;元宇宙的概念如同一颗璀璨的新星&#xff0c;吸引了全球的目光。元宇宙被描绘为一个平行于现实世界、又与现实世界相互影响且始终在线的虚拟空间&#xff0c;它整合了多种前沿技术&#xff0c;为人们带来沉浸式的交互体验。而数字孪生&…...

WPF 附加属性

在WPF&#xff08;Windows Presentation Foundation&#xff09;中&#xff0c;附加属性&#xff08;Attached Properties&#xff09;是一种特殊的依赖属性机制&#xff0c;它允许父元素为子元素提供额外的属性支持。这种特性特别适用于布局系统、输入处理和其他需要跨多个控件…...

数据分析 之 怎么看懂图 一

韦恩图怎么看 ①颜色:不同颜色代表不同的集合 ②)颜色重叠部分:表示相交集合共有的元素 ③颜色不重叠的部分:表示改集合独有的元素 ④数字:表示集合独有或共有的元素数量 ⑤百分比:表示该区域元素数占整体的比例 PCA图怎么看 ① 第一主成分坐标轴及主成分贡献率主成分贡献…...

手写数据库MYDB(一):项目启动效果展示和环境配置问题说明

1.项目概况 这个项目实际上就是一个轮子项目&#xff0c;现在我看到的这个市面上面比较火的就是这个首先RPC&#xff0c;好多的机构都在搞这个&#xff0c;还有这个消息队列之类的&#xff0c;但是这个是基于MYSQL的&#xff0c;我们知道这个MYSQL在八股盛宴里面是重点考察对象…...

深入理解椭圆曲线密码学(ECC)与区块链加密

椭圆曲线密码学&#xff08;ECC&#xff09;在现代加密技术中扮演着至关重要的角色&#xff0c;广泛应用于区块链、数字货币、数字签名等领域。由于其在提供高安全性和高效率上的优势&#xff0c;椭圆曲线密码学成为了数字加密的核心技术之一。本文将详细介绍椭圆曲线的基本原理…...

使用 PowerShell 脚本 + FFmpeg 在 Windows 系统中批量计算 MP4视频 文件的总时长

步骤 1&#xff1a;安装 FFmpeg 访问 FFmpeg 官网(Download FFmpeg)&#xff0c;下载 Windows 版编译包&#xff08;如 ffmpeg-release-full.7z&#xff09;。或者到&#xff08;https://download.csdn.net/download/zjx2388/90539014&#xff09;下载完整资料 解压文件&#…...

中医气血精津辨证

中医气血精津辨证 一、气血精津辨证概述 基本概念&#xff1a; 气血精津是构成人体和维持生命活动的基本物质&#xff0c;其生成、运行、输布与脏腑功能密切相关。辨证核心&#xff1a;通过分析气血精津的盛衰、运行障碍及其相互关系&#xff0c;判断疾病本质。 生理关系&…...

Intellij IDEA2023 创建java web项目

Intellij IDEA2023 创建java web项目 零基础搭建web项目1、创建java项目2、创建web项目3、创建测试页面4、配置tomcat5、遇到的问题 零基础搭建web项目 小白一枚&#xff0c;零基础学习基于springMVC的web项目开发&#xff0c;记录开发过程以及中间遇到的问题。已经安装了Inte…...

Scrapy结合Selenium实现滚动翻页数据采集

引言 在当今的互联网数据采集领域&#xff0c;许多网站采用动态加载技术&#xff08;如AJAX、无限滚动&#xff09;来优化用户体验。传统的基于Requests或Scrapy的爬虫难以直接获取动态渲染的数据&#xff0c;而Selenium可以模拟浏览器行为&#xff0c;实现滚动翻页和动态内容…...

Node.js从0.5到1学习计划

以下是针对零基础学习者的10天Node.js高效学习计划&#xff0c;每天聚焦核心知识点并配合实战练习&#xff1a; &#x1f4c6; 10天Node.js速成计划&#xff08;每日4-6小时&#xff09; 核心目标&#xff1a;掌握Node.js核心机制 完成3个实战项目 &#x1f4cd; Day 1-2&…...

python 的 obj的key 变成双引号

在Python中&#xff0c;当你序列化一个对象&#xff08;例如使用json.dumps()方法将对象转换为JSON字符串&#xff09;时&#xff0c;默认情况下&#xff0c;字典的键&#xff08;keys&#xff09;会被转换为字符串。如果你的字典中的键本身就是字符串&#xff0c;并且你想要在…...