一文搞懂 MCP Servers
一文搞懂 MCP Servers
什么是MCP
MCP概念
MCP(Model Context Protocol,模型上下文协议)是由 Anthropic 提出并于 2024 年 11 月开源的一种通信协议,旨在解决大型语言模型(LLM)与外部数据源及工具之间无缝集成的需求。
它通过标准化 AI 系统与数据源的交互方式,帮助模型获取更丰富的上下文信息,从而生成更准确、更相关的响应。
主要功能
上下文共享:应用程序可以通过 MCP 向模型提供所需的上下文信息(如文件内容、数据库记录等),增强模型的理解能力。工具暴露:MCP 允许应用程序将功能(如文件读写、API 调用)暴露给模型,模型可以调用这些工具完成复杂任务。可组合的工作流:开发者可以利用 MCP 集成多个服务和组件,构建灵活、可扩展的 AI 工作流。安全性:通过本地服务器运行,MCP 避免将敏感数据上传至第三方平台,确保数据隐私。
MCP架构
MCP 采用客户端-服务器架构:
MCP 客户端(Client):通常是 AI 应用程序(如 Claude Desktop 或其他 LLM 工具),负责发起请求并与服务器通信。MCP 服务器(Server):轻量级程序,负责暴露特定的数据源或工具功能,并通过标准化协议与客户端交互。
通信格式:基于 JSON-RPC 2.0,支持请求、响应和通知三种消息类型,确保通信的标准化和一致性。
MCP Servers主要功能
MCP Servers 作为一个轻量级的本地服务,旨在为客户端提供数据访问和功能执行的接口。
1. 资源暴露(Resource Exposure)
资源是服务器提供给客户端的数据实体,可以是文件、数据库记录、内存中的对象等。
例如:
- 文件资源:
file:///home/user/report.txt - 内存资源:
memo://recent-insights
2. 工具提供(Tool Provisioning)
工具是服务器暴露的可执行功能,客户端可以通过调用这些工具完成特定任务。
例如:
- 查询数据库:
query_database(参数:SQL 语句,返回:查询结果) - 文件写入:
write_file(参数:文件路径、内容)
3. 动态通知(Dynamic Notification)
当资源发生变化时,服务器可以通过通知机制(如 notification 消息)主动推送更新到客户端。
4. 会话管理(Session Management)
处理客户端的连接初始化、能力协商和会话关闭。
自定义 MCP Servers
- 本地实现一个文件资源服务,创建
mcp_server.py文件。
import json
import sys
# 处理客户端请求
def handle_request(request):
method = request.get("method")
params = request.get("params", {})
request_id = request.get("id")
if method == "initialize":
return {
"jsonrpc": "2.0",
"result": {"version": "1.0", "capabilities": ["resources", "tools"]},
"id": request_id
}
elif method == "read_resource":
uri = params.get("uri")
with open(uri.replace("file:///", ""), "r") as f:
content = f.read()
return {"jsonrpc": "2.0", "result": content, "id": request_id}
elif method == "call_tool":
tool_name = params.get("name")
if tool_name == "echo":
return {"jsonrpc": "2.0", "result": params.get("message"), "id": request_id}
else:
return {"jsonrpc": "2.0", "error": {"code": -32601, "message": "Method not found"}, "id": request_id}
# 主循环:通过 Stdio 通信
def main():
while True:
# 从 stdin 读取请求
raw_input = sys.stdin.readline().strip()
if not raw_input:
break
request = json.loads(raw_input)
# 处理请求并返回响应
response = handle_request(request)
sys.stdout.write(json.dumps(response) + "\n")
sys.stdout.flush()
if __name__ == "__main__":
main()
- 通过 python 启动服务
python mcp_server.py
- 在相同的目录下创建
test.txt文件。
Hello, this is a test file!
- 另外启动一个命令窗口,输入:
echo '{"jsonrpc": "2.0", "method": "read_resource", "params": {"uri": "file:///D:/path/to/test.txt"}, "id": 2}' | python mcp_server.py
{"jsonrpc": "2.0", "result": "Hello, this is a test file!", "id": 2}
注:此处使用的是 PowerShell,我们看到服务返回了文件的内容。
使用现有 MCP Servers
GitHub:在 GitHub 上查找 MCP servers:
网站:通过下面的网站查找 MCP servers:
UI自动化相关的 MCP servers
playwright: https://github.com/executeautomation/mcp-playwrightbrowserbase: https://github.com/browserbase/mcp-server-browserbasepuppeteerhttps://github.com/modelcontextprotocol/servers/tree/HEAD/src/puppeteer
我们以 Playwright 项目为例子。
playwright 项目:https://github.com/AutoTestClass/playwright-mind
在项目里添加 playwright-mcp-server:
git clone https://github.com/AutoTestClass/playwright-mind
cd playwright-mind
npm install -g @executeautomation/playwright-mcp-server # <--添加--
MCP Client
MCP client 一般选用 AI 应用程序(如 Claude Desktop、cline 或其他 LLM 工具),负责发起请求并与服务器通信。
我们这里选用 VSCode + cline 的组合,关于二者的使用,铺天盖地都是使用的文章,这里就不介绍了。
- 首先,在 VSCode 中打开 cline 插件,在 MCP servers 中搜索
playwright插件安装。

- 然后,配置
playwright mcp servers的启动配置。

{
"mcpServers": {
"playwright": {
"command": "npx",
"args": ["-y", "@executeautomation/playwright-mcp-server"]
}
}
}
- 最后,通过 LLM 大模型,描述需求(UI 自动化相关操作),LLM 大模型会通过
playwright MCP servers启动浏览器完成一些 UI 自动化操作。

MCP Servers的作用
最后,我们再来总结 MCP Servers 的作用。懒得画图了,下面是我网上找的一张图。结合前面的操作流程,相信你已经知道 MCP Servers 可以做什么了。

MCP Servers 真正的价值不在于我们传统的 UI 自动化测试,因为它是通过文字描述操作浏览器去完成一些工作。并没有自动化的脚本沉淀,当然,如果你把 Prompt 沉淀下来当作自动化脚本也是可以的,这确实颠覆了我们写自动化脚本的形式。
当然,MCP Servers 更多的价值不是浏览器自动化,而是利用 LLM 操作本地资源,例如,本地文件,数据库、git 等。想想 你不需要写复杂的 SQL 语句,通过自然语言描述就可以轻松完成本地数据库的操作。 这种效率的提升是非常明显。

一文搞懂 MCP Servers的更多相关文章
- 一文搞懂RAM、ROM、SDRAM、DRAM、DDR、flash等存储介质
一文搞懂RAM.ROM.SDRAM.DRAM.DDR.flash等存储介质 存储介质基本分类:ROM和RAM RAM:随机访问存储器(Random Access Memory),易失性.是与CPU直接 ...
- 基础篇|一文搞懂RNN(循环神经网络)
基础篇|一文搞懂RNN(循环神经网络) https://mp.weixin.qq.com/s/va1gmavl2ZESgnM7biORQg 神经网络基础 神经网络可以当做是能够拟合任意函数的黑盒子,只 ...
- 一文搞懂 Prometheus 的直方图
原文链接:一文搞懂 Prometheus 的直方图 Prometheus 中提供了四种指标类型(参考:Prometheus 的指标类型),其中直方图(Histogram)和摘要(Summary)是最复 ...
- Web端即时通讯基础知识补课:一文搞懂跨域的所有问题!
本文原作者: Wizey,作者博客:http://wenshixin.gitee.io,即时通讯网收录时有改动,感谢原作者的无私分享. 1.引言 典型的Web端即时通讯技术应用场景,主要有以下两种形式 ...
- 一文搞懂vim复制粘贴
转载自本人独立博客https://liushiming.cn/2020/01/18/copy-and-paste-in-vim/ 概述 复制粘贴是文本编辑最常用的功能,但是在vim中复制粘贴还是有点麻 ...
- 三文搞懂学会Docker容器技术(中)
接着上面一篇:三文搞懂学会Docker容器技术(上) 6,Docker容器 6.1 创建并启动容器 docker run [OPTIONS] IMAGE [COMMAND] [ARG...] --na ...
- 三文搞懂学会Docker容器技术(下)
接着上面一篇:三文搞懂学会Docker容器技术(上) 三文搞懂学会Docker容器技术(中) 7,Docker容器目录挂载 7.1 简介 容器目录挂载: 我们可以在创建容器的时候,将宿主机的目录与容器 ...
- 一文搞懂所有Java集合面试题
Java集合 刚刚经历过秋招,看了大量的面经,顺便将常见的Java集合常考知识点总结了一下,并根据被问到的频率大致做了一个标注.一颗星表示知识点需要了解,被问到的频率不高,面试时起码能说个差不多.两颗 ...
- 一文搞懂 js 中的各种 for 循环的不同之处
一文搞懂 js 中的各种 for 循环的不同之处 See the Pen for...in vs for...of by xgqfrms (@xgqfrms) on CodePen. for &quo ...
- 一文搞懂如何使用Node.js进行TCP网络通信
摘要: 网络是通信互联的基础,Node.js提供了net.http.dgram等模块,分别用来实现TCP.HTTP.UDP的通信,本文主要对使用Node.js的TCP通信部份进行实践记录. 本文分享自 ...
随机推荐
- nodejs koa2 ocr识别 身份证信息
1. 安装依赖 npm install baidu-aip-sdk 2.创建AipOcrClient 注:需要到百度api创建应用,拿到所需的APPID/AK/SK https://console.b ...
- 金Gien乐道 | 8月热点回顾
中电金信2023年中工作会议:加快推进以"源启"为基石的业务模式转型 8月12日,中电金信2023年中工作会议在上海召开.会议贯彻落实中国电子2023年中工作会议精神,总结上半 ...
- web应用模式、API接口、接口测试工具postman、restful规范
目录 一.web 应用模式 二.API接口 API概念 三.接口测试工具postman postman介绍 postman下载与使用 四.如何在浏览器中测试 五.restful规范(重要,不难) 概念 ...
- 【机器学习】SVM(支持向量机)算法实验
(一)实验名称:SVM(支持向量机)算法实验 (二)实验目的: 学习支持向量机SVM的基本概念 了解核函数的基本概念 掌握使用scikit-learn API函数实现SVM算法 (三)实验内容:使用s ...
- 微信小程序无法抓包
1.问题 1.1. 问题描述 夜神模拟器中,微信小程序请求超时(是因为开了抓包程序) 1.2. 问题截图 2.解决问题 2.1. 步骤 开启调试模式,之后重启小程序 2.2. 结果
- Spring MVC 中 DefaultServletHandlerConfigurer
<mvc:default-servlet-handler/> 这个Spring MVC xml文件的属性,主要是处理web项目的静态文件问题. 每次请求过来,先经过 DefaultServ ...
- Chaincode installation on peer0.org1 has failed
v1.4 版本执行 ./byfn.sh up时,报如下错误 Error: error getting chaincode deployment spec for mycc: error getting ...
- 深入Python胶水语言的本质:从CPython到各类扩展机制
在开始深入讲解Python如何作为胶水语言之前,我们需要先了解Python语言本身的实现机制.这对于理解Python如何与C语言交互至关重要. CPython:Python的默认实现 当我们谈论Pyt ...
- JVM实战—5.G1垃圾回收器的原理和调优
大纲 1.G1垃圾回收器的工作原理 2.G1分代回收原理-性能为何比传统GC好 3.使用G1垃圾回收器时应如何设置参数 4.如何基于G1垃圾回收器优化性能 5.问题汇总 1.G1垃圾回收器的工作原理 ...
- RESTful 架构详解-copy
1. 什么是REST REST全称是Representational State Transfer,中文意思是表述(编者注:通常译为表征)性状态转移. 它首次出现在2000年Roy Fielding的 ...