基于FastMCP创建MCP服务器的小白级教程

以下是基于windows 11操作系统环境的开发步骤。

1、python环境搭建

访问官网:https://www.python.org/。下载相应的版本(如:3.13.5),然后安装。

安装完成之后,使用命令行工具输入python,显示如下图即可安装成功。

2、fastmcp项目的初始化

fastmcp的文档地址:FastMCP MCP框架,推荐使用UV来安装和管理 FastMCP。

我要在H:\mcp-demo文件夹下创建我的项目,使用vs code打开该文件夹项目。

(1)UV的安装

进入UV官网的安装文档Installation | uv,如下图:

安装完成之后,在命令行里录入UV时,出现如下信息,即为安装成功:

(2)使用UV来初始化项目,如下图:

即可自动初始化如下图所示的项目:

(3)使用uv创建python虚拟环境

项目目录里多了一个文件夹。

(4)按照上一步的提示,使用".venv\Scripts\activate"进行激话,因为我们是windows环境,所以打开.venv目录查看

使用.venv\Scripts\activate.bat

bash 复制代码
.venv\Scripts\activate.bat

这个时候,项目的环境变量更新了。验证方式:输入python,即可出现我们希望的python版本信息,如图

使用exit()退回。

(5)安装fastmcp

参考fastmcp文档

bash 复制代码
uv pip install fastmcp

等待安装完成。

3、编写mcp工具和资源

安装完成之后,即可编写代码,打开main.py文件,参考官方示例代码如下:

python 复制代码
import os
from pathlib import Path
from typing import List,Dict
from fastmcp import FastMCP

mcp= FastMCP(name="我的文件MCP服务器")

# 在应用启动前设置
# os.environ["DANGEROUSLY_OMIT_AUTH"] = "true"

@mcp.tool(description="获取当前电脑桌面的路径")
def get_desktop() -> str:
    return f"H:\mcp-demo"

@mcp.tool(description="遍历文件夹下的所有文件")
def list_files_in_directory(directory_path: str) -> List[str]:
    path = Path(directory_path)

    if not path.exists() or not path.is_dir():
        return [{"error": "指定的路径不存在或不是一个目录"}]
    
    files=[]
    for file in path.iterdir():
        if file.is_file():
            files.append({"file_name":file.name, "file_path": str(file)})
    return files


@mcp.tool(description="搜索文件夹下的特定文件")
def search_files(directory_path: str, keyword: str) -> List[Dict[str, str]]:
    path = Path(directory_path)

    if not path.exists() or not path.is_dir():
        return [{"error": "指定的路径不存在或不是一个目录"}]
    
    results = []
    for file in path.iterdir():
        if file.is_file() and keyword.lower() in file.name.lower():
            results.append({"file_name": file.name, "file_path": str(file)})
    
    return results


# def main():
#    print("Hello from workon-mcp!")


if __name__ == "__main__":
    # main()
    mcp.run()  # 启动MCP服务器 # Default: uses STDIO transport
    # mcp.run(transport="sse", host="127.0.0.1", port=8000)

4、运行测试

使用 fastmcp run 来进行运行调试。

相关推荐
看海天一色听风起雨落16 小时前
Python学习之装饰器
开发语言·python·学习
XiaoMu_00117 小时前
基于Python+Streamlit的旅游数据分析与预测系统:从数据可视化到机器学习预测的完整实现
python·信息可视化·旅游
THMAIL17 小时前
深度学习从入门到精通 - 生成对抗网络(GAN)实战:创造逼真图像的魔法艺术
人工智能·python·深度学习·神经网络·机器学习·生成对抗网络·cnn
小小菜鸡ing17 小时前
pymysql
java·服务器·数据库
Mr. Cao code17 小时前
Docker:颠覆传统虚拟化的轻量级革命
linux·运维·ubuntu·docker·容器
我没想到原来他们都是一堆坏人18 小时前
(未完待续...)如何编写一个用于构建python web项目镜像的dockerfile文件
java·前端·python
wanhengidc18 小时前
云手机运行流畅,秒开不卡顿
运维·网络·科技·游戏·智能手机
总有刁民想爱朕ha19 小时前
车牌模拟生成器:Python3.8+Opencv代码实现与商业应用前景(C#、python 开发包SDK)
开发语言·python·数据挖掘
笨小孩@GF 知行合一19 小时前
OSPF实验:外部路由引入
运维·网络·hcip·数通·ospf
asdfg125896319 小时前
为什么要在出口路由器router配置NAT与默认路由
运维·网络·计算机网络