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

MCP Server Resource 开发学习文档

MCP Server Resource 开发学习文档

目录

  1. 简介
  2. 主要依赖与环境准备
  3. 服务器核心结构与原理
    • 资源定义与管理
    • 资源列表接口实现
    • 资源读取接口实现
    • 传输方式(stdio 与 sse)
  4. 源码详细解析
  5. SSE 方式本地部署方法
  6. 客户端访问 SSE 服务示例

1. 简介

MCP(Modular Communication Protocol)是一种用于模块化服务通信的协议。本文以 simple-resource 服务器为例,讲解如何开发一个简单的 MCP 资源服务器,将本地文本资源以标准接口暴露给客户端访问。


2. 主要依赖与环境准备

  • Python 3.8+
  • anyio
  • click
  • pydantic
  • starlette
  • uvicorn
  • mcp(自定义/三方库)

安装依赖(假设 requirements.txt 已配置):

pip install -r requirements.txt

3. 服务器核心结构与原理

3.1 资源定义与管理

资源以字典形式存储,key 为资源名,value 为资源内容:

SAMPLE_RESOURCES = {"greeting": "Hello! This is a sample text resource.","help": "This server provides a few sample text resources for testing.","about": "This is the simple-resource MCP server implementation.",
}

3.2 资源列表接口实现

通过 @app.list_resources() 装饰器注册资源列表接口,返回所有可用资源的元数据:

@app.list_resources()
async def list_resources() -> list[types.Resource]:return [types.Resource(uri=AnyUrl(f"file:///{name}.txt"),name=name,description=f"A sample text resource named {name}",mimeType="text/plain",)for name in SAMPLE_RESOURCES.keys()]
  • uri:资源唯一标识,采用 file 协议
  • name:资源名
  • description:资源描述
  • mimeType:资源类型

3.3 资源读取接口实现

通过 @app.read_resource() 装饰器注册资源读取接口,按 uri 读取资源内容:

@app.read_resource()
async def read_resource(uri: AnyUrl) -> str | bytes:if uri.path is None:raise ValueError(f"Invalid resource path: {uri}")name = uri.path.replace(".txt", "").lstrip("/")if name not in SAMPLE_RESOURCES:raise ValueError(f"Unknown resource: {uri}")return SAMPLE_RESOURCES[name]
  • 校验 uri 合法性
  • 解析资源名
  • 返回对应资源内容

3.4 传输方式(stdio 与 sse)

  • stdio:标准输入输出,适合本地进程间通信
  • sse:Server-Sent Events,基于 HTTP,适合网络通信

通过命令行参数 --transport 选择,默认 stdio。


4. 源码详细解析

4.1 主函数入口

@click.command()
@click.option("--port", default=8000, help="Port to listen on for SSE")
@click.option("--transport",type=click.Choice(["stdio", "sse"]),default="stdio",help="Transport type",
)
def main(port: int, transport: str) -> int:app = Server("mcp-simple-resource")# ...注册接口...if transport == "sse":# SSE 相关逻辑else:# stdio 相关逻辑return 0
  • 使用 click 实现命令行参数解析
  • 根据 transport 参数选择不同的服务启动方式

4.2 SSE 传输实现

if transport == "sse":from mcp.server.sse import SseServerTransportfrom starlette.applications import Starlettefrom starlette.responses import Responsefrom starlette.routing import Mount, Routesse = SseServerTransport("/messages/")async def handle_sse(request):async with sse.connect_sse(request.scope, request.receive, request._send) as streams:await app.run(streams[0], streams[1], app.create_initialization_options())return Response()starlette_app = Starlette(debug=True,routes=[Route("/sse", endpoint=handle_sse, methods=["GET"]),Mount("/messages/", app=sse.handle_post_message),],)import uvicornuvicorn.run(starlette_app, host="0.0.0.0", port=port)
  • 使用 Starlette 框架搭建 HTTP 服务
  • /sse 路由用于 SSE 连接
  • /messages/ 路由用于消息传递
  • 通过 uvicorn 启动服务

4.3 stdio 传输实现

else:from mcp.server.stdio import stdio_serverasync def arun():async with stdio_server() as streams:await app.run(streams[0], streams[1], app.create_initialization_options())anyio.run(arun)
  • 适合本地开发和测试

5. SSE 方式本地部署方法

5.1 启动 SSE 服务

在 simple-resource 目录下运行:

uv run mcp-simple-resource --transport sse --port 8000

或直接用 Python 启动:

python mcp_simple_resource/server.py --transport sse --port 8000
  • 服务将监听本地 8000 端口,SSE 路径为 /sse

6. 客户端访问 SSE 服务示例

6.1 Python 客户端示例

假设有 mcp 客户端库,示例代码如下:

import asyncio
from mcp.types import AnyUrl
from mcp.client.session import ClientSession
from mcp.client.sse import SseServerParameters, sse_clientasync def main():async with sse_client(SseServerParameters(url="http://localhost:8000/sse")) as (read, write):async with ClientSession(read, write) as session:await session.initialize()# 列出所有资源resources = await session.list_resources()print(resources)# 读取特定资源resource = await session.read_resource(AnyUrl("file:///greeting.txt"))print(resource)asyncio.run(main())
  • SseServerParameters 指定服务端地址
  • list_resources() 获取资源列表
  • read_resource() 读取具体资源内容

总结

本文详细介绍了 MCP simple-resource 服务器的开发原理、源码结构、接口实现、SSE 部署与客户端访问方法。通过本例,开发者可以快速理解如何基于 MCP 协议开发自定义资源服务,并通过多种传输方式对接客户端。

http://www.xdnf.cn/news/8141.html

相关文章:

  • 记一次奇葩的错误,uniapp @tap点击失效
  • Nockchain项目部署教程
  • 从连接中枢到终端接入——解析工业无线AP与客户端的协同之道
  • 安装部署配置jenkins
  • Nginx 1.25.4交叉编译问题:编译器路径与aclocal.m4错误解决方案
  • wifi 如果检查失败,UI 就会出现延迟或缺失打勾的现象。
  • linux中部署jdk,开机自启动jdk以及linux中java开机自启某个jar包文件
  • 算法第26天 | 贪心算法、455.分发饼干、376. 摆动序列、 53. 最大子序和
  • 如何在Java中进行PDF合并
  • 软考 系统架构设计师系列知识点之杂项集萃(69)
  • Linux Shell编程(五)
  • 【鸿蒙开发】Hi3861学习笔记-超声波测距
  • HTB-Titanic
  • 多模态大语言模型arxiv论文略读(八十八)
  • LeetCode面试经典150题梳理
  • java I/O
  • 【补题】The 2021 ICPC Asia Nanjing Regional Contest Problem J. Xingqiu’s Joke
  • [Java][Leetcode middle] 6. Z 字形变换
  • TCP与UDP协议全面对比:从原理到应用场景深度解析
  • ROS2 camera_calibration 双目相机标定指令
  • 监控易一体化运维:网络拓扑管理,网络管理高效之道
  • 异常数据的检测
  • 【基础】Windows开发设置入门11:hyper-v虚拟机创建
  • 批处理操作优化思路
  • 使用Pyinstaller打包python,全过程解析【2025最详细】
  • 湖北理元理律师事务所:专业债务优化如何助力负债者重获生活掌控权
  • CS和BS架构
  • 《数据结构笔记一》: 指针、结构体、动态内存分配、算法时间复杂度。
  • Python绘制3D图表
  • PostgreSQL 18 升级新体验:pg_upgrade --swap 极简教程