从零构建自己的MCP Server

前言

最近一直在研究 MCP,感觉这个协议真的会将大模型从单纯的对话发展为干活,前几天,连 Open AI 也已经选择跟进了。

前面,我们先了解了 MCP 的理论概念《一文读懂MCP:助力大模型接入合规"四肢" - 掘金》,然后,也掌握了如何使用现有的 MCP Server 扩展大模型能力《自动Bug清道夫:Gitee MCP Server初探 - 掘金》。

这次,我们就分享一下,如何自己实现一套 MCP Server

本次分享为了降低开发难度,场景选择了非常基础的"文件系统"场景,客户端使用之前推荐的 Cherry Studio。

环境准备

本次分享使用 Python 开发,开发工具依然使用 Cursor。

基础环境

Python,版本为 3.12。

设置 Python 虚拟环境

隔离依赖影响。

Ctrl+Shift+P 选择 Python:Create Environment

我使用的是venv方式,选择上面安装的Python版本即可。

安装 MCP 官方 SDK。

在 Cursor 终端中使用 pip 安装官方 SDK,代码中使用:

复制代码
pip install mcp

可以同时安装 mcp[cli],运行调试使用。

css 复制代码
pip install mcp[cli] 

安装完成后可通过 mcp version 验证版本。

实现 MCP Server

代码

创建main.py,录入如下代码。

记得更改代码中的桌面路径

python 复制代码
import os
from mcp.server.fastmcp import FastMCP

mcp = FastMCP()  # 初始化 MCP 服务实例

@mcp.tool()
def get_desktop_files():
    """获取桌面上的文件列表"""
    return os.listdir(os.path.expanduser("<桌面路径>"))

if __name__ == "__main__":
    mcp.run(transport='stdio')  # 启动服务,使用标准输入输出通信

关键点解析

  • @mcp.tool() 注解:声明此函数为 MCP 工具,客户端会自动发现该接口。
  • 函数注释:必须,详细描述功能和参数,大模型依赖注释理解接口用途。
  • 通信协议:transport='stdio' 表示使用标准输入输出,也可替换为 HTTP 或 WebSocket。

启动调试

终端使用 mcp 命令启动,使用的就是上面安装的 mcp[cli]。

底层使用的是官网提供的一套 web 界面,可以直接测试 MCP Server是否正常。

css 复制代码
mcp dev .\main.py

验证

访问 http://localhost:5173,左侧指令区域录入:

  • Command:直接保留 uv 即可,此处是 pip install 的,使用 python 虚拟环境,不需要绝对路径即可。
  • Arguments:复制"启动调试"控制台内容中的args即可。(上图红框内)

如果配置正常,点击 Connect 按钮后,下方会出现绿点和"Connected"字样。

到此,服务端已经开发完成。

客户端调用

客户端直接采用Cherry Studio

详细说明可参考官网文档:docs.cherry-ai.com/advanced-ba...

准备工作:安装 uv、bun

Cherry Studio 目前只使用内置的 uv 和 bun,即需要保证如下位置有对应的exe文件。

文件位置:

  • Windows: C:\Users\用户名.cherrystudio\bin
  • macOS,Linux: ~/.cherrystudio/bin

安装方式有两种:

配置 MCP 服务器

设置 - MCP 服务器 中"添加服务器"即可。

  • 名称:随便起,容易区分即可。
  • 类型:我们使用的是命令启动,所以选择 STDIO
  • 命令和参数:核心配置,和服务端验证时输入的内容类似,我为了省劲,直接都放到了"命令"中。
javascript 复制代码
C:/Users/xxx/.cherrystudio/bin/uv.exe run D:/xxx/mcp-hello/main.py

这里强烈建议vu.exe采用绝对路径

聊天框中使用 MCP

新建对话:

  1. 启用 MCP 服务器
  2. 选择支持 函数调用 的模型,使用的 Qwen2.5-7B-Instruct
  3. 发送指令"我的桌面有哪些文件"。

即可看到调用我们的工具 get_desktop_files,并返回了正确的文件列表。

总结

整个过程还是比较顺利的,但是大家一定要注意区分服务端客户端基础环境路径。比如:开发调试的 uv 是通过 pip install mcp[cli] 安装的,而客户端的 uv 是 CherryStudio 内的。

本次分享主要给大家展示下 MCP Server 开发的整个流程及开发的注意事项,后续会针对实际场景继续给大家分享。

相关推荐
flex88881 分钟前
FramePack - 开源 AI 视频生成工具
人工智能·开源·音视频
jndingxin36 分钟前
OpenCV CUDA模块中矩阵操作------范数(Norm)相关函数
人工智能·opencv
何双新1 小时前
第6讲、全面拆解Encoder、Decoder内部模块
人工智能
jzwei0231 小时前
Transformer Decoder-Only 算力FLOPs估计
人工智能·深度学习·transformer
lilye661 小时前
精益数据分析(55/126):双边市场模式的挑战、策略与创业阶段关联
大数据·人工智能·数据分析
weixin_408266341 小时前
深度学习-分布式训练机制
人工智能·分布式·深度学习
struggle20251 小时前
AgenticSeek开源的完全本地的 Manus AI。无需 API,享受一个自主代理,它可以思考、浏览 Web 和编码,只需支付电费。
人工智能·开源·自动化
Panesle1 小时前
阿里开源通义万相Wan2.1-VACE-14B:用于视频创建和编辑的一体化模型
人工智能·开源·大模型·文生视频·多模态·生成模型
QQ2740287562 小时前
Kite AI 自动机器人部署教程
linux·运维·服务器·人工智能·机器人·web3
巷9552 小时前
OpenCV光流估计:原理、实现与应用
人工智能·opencv·计算机视觉