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

如何使用 FastAPI 构建 MCP 服务器

哎呀,各位算法界的小伙伴们!今天咱们要聊聊一个超酷的话题——MCP 协议!你可能已经听说了,Anthropic 推出了这个新玩意儿,目的是让 AI 代理和你的应用程序之间的对话变得更顺畅、更清晰。不过别担心,为你的 Python 应用程序搭建一个这样的服务器并不复杂,甚至可以说简单到让你怀疑人生!

为什么需要它?

  • 允许 AI 代理与您的应用程序集成
    想象一下,AI 就像你的私人助理,而 MCP 就是它和你家大门之间的钥匙。

  • 将复杂性从人类开发者转移到 AI 代理
    让 AI 去操心那些繁琐的逻辑吧,咱就负责躺平享受成果。

  • 简化将 AI 连接到众多工具和数据源的过程
    不管你是想连数据库还是接 API,MCP 都能帮你搞定。

如果 MCP 成为下一个行业标准(已经火起来了,看起来可能性非常之大),那你只能选择跟上潮流。毕竟,别人家的 AI 都在忙着自动集成,你总不能还手动敲代码吧?更何况,等你看到实现它所需的代码量时,你会觉得自己简直是个天才!


如何做?

创建具有所需功能的 FastAPI 服务器

(如果你已经有了一个,请直接跳过此步骤)

FastAPI 的入门教程肯定比我的讲解更专业,但我会尽量用接地气的方式给你讲清楚:

安装依赖项:
pip install uvicorn, fastapi
创建一个 FastAPI 服务器:
from fastapi import FastAPIapp = FastAPI()@app.get("/")
async def root():return {"message": "MCP 超级酷"}  # 返回一条消息,告诉世界 MCP 很棒

对于应用的每个功能,编写一个“路径操作”——也就是分配给特定路径的函数(比如这里的根函数位于路径 / 下),执行 HTTP 操作(GET、POST、PUT、DELETE…)。然后用 uvicorn 运行你的应用:

uvicorn main:app --reload

搞定!你的 FastAPI 应用现在可以在 http://127.0.0.1:8000 上访问啦。接下来,让我们把它升级成一个真正的 MCP 服务器!

插图


从 FastAPI 到 MCP 服务器

安装开源工具 fastapi-mcp:

pip install fastapi-mcp ## 这行代码价值一个亿

特性

  • 直接集成 - 将 MCP 服务器直接挂载到您的 FastAPI 应用中
  • 零配置要求 - 只需将其指向您的 FastAPI 应用即可正常运行
  • 自动发现所有 FastAPI 端点并转换为 MCP 工具
  • 保留请求模型和响应模型的架构
  • 保留所有端点的文档,就像在 Swagger 中一样
  • 可扩展性 - 在自动生成的工具之外添加自定义 MCP 工具

基础用法

添加到你的 FastAPI 代码:

from fastapi import FastAPI
from fastapi_mcp import add_mcp_server# 您的 FastAPI 应用
app = FastAPI()# 把 MCP 服务器挂载到你的应用上,就像给舞台装上聚光灯
add_mcp_server(app,                 # 您的 FastAPI 应用mount_path="/mcp",   # 在哪里挂载 MCP 服务器name="我的 API MCP",   # MCP 服务器的名称
)

高级玩法

FastAPI - MCP 还有很多隐藏技能,能让你随心所欲地定制和控制 MCP 服务器的创建和配置,就像玩一场超级酷炫的游戏:

from fastapi import FastAPI
from fastapi_mcp import add_mcp_serverapp = FastAPI()mcp_server = add_mcp_server(app,                                    # 你的 FastAPI 应用mount_path="/mcp",                      # MCP 服务器挂载的位置name="My API MCP",                      # MCP 服务器的名字describe_all_responses=True,            # 默认是 False。就像打开一个百宝箱,把所有可能的响应模式都包含在工具描述里,而不只是成功的响应。describe_full_response_schema=True      # 默认是 False。把完整的 JSON 模式包含在工具描述里,而不只是一个对大语言模型友好的响应示例。
)# 你还可以像变魔术一样,在现有 API 的基础上添加自定义工具。
@mcp_server.tool()
async def get_server_time() -> str:"""获取当前服务器时间。就像从时间老人那里偷来一点时间信息"""from datetime import datetimereturn datetime.now().isoformat()

就这样!MCP 服务器自动生成并可在 http://127.0.0.1:8000/mcp 上访问。这是一个可以在 Cursor(或者任何支持 SSE 的 AI 代理,据说 Cline 对 MCP 的支持也快来了)中配置的地址。


使用 MCP

通过 SSE 连接 MCP 服务器

当你的集成了 MCP 的 FastAPI 应用运行起来后,你可以用任何支持 SSE 的 MCP 客户端连接它,比如 Cursor,就像用一把神奇的钥匙打开宝藏大门:

  1. 启动你的应用,就像启动一辆超级跑车。
  2. 在 Cursor -> 设置 -> MCP 里,把你的 MCP 服务器端点的 URL(比如 http://localhost:8000/mcp)作为 SSE 地址,就像给跑车设置目的地。
  3. Cursor 会像一个聪明的小侦探,自动发现所有可用的工具和资源。

通过 mcp - proxy stdio 连接 MCP 服务器

要是你的 MCP 客户端不支持 SSE,比如 Claude Desktop,也别担心,我们有办法:

  1. 启动你的应用,让它像个活力满满的小机器人一样跑起来。
  2. 安装 mcp - proxy,比如:uv tool install mcp-proxy,就像给小机器人装上一个新的配件。
  3. 在 Claude Desktop 的 MCP 配置文件 (claude_desktop_config.json) 里添加以下内容:
Windows 系统
{"mcpServers": {"my-api-mcp-proxy": {"command": "mcp-proxy","args": ["http://127.0.0.1:8000/mcp"]}}
}
MacOS 系统
{"mcpServers": {"my-api-mcp-proxy": {"command": "/Full/Path/To/Your/Executable/mcp-proxy","args": ["http://127.0.0.1:8000/mcp"]}}
}

在终端里运行 which mcp - proxy 就能找到 mcp - proxy 的路径,就像在迷宫里找到正确的路。


接下来是什么?

一旦设置完成,AI 代理现在可以通过标准化协议与你的应用程序交互了!你可以通过添加更多端点来扩展你的 MCP 服务器,暴露应用程序的不同功能。

记住,MCP 的目标是让集成变得简单——所以千万别搞得太复杂!从基本功能开始,根据需要逐步扩展。

使用 FastAPI 和 fastapi-mcp 库的好处在于,你保留了 FastAPI 的所有优势(比如自动文档和类型验证),同时通过最少的额外代码添加了 MCP 功能。

如果你尝试了,请告诉我,并别忘了给 fastapi-mcp仓库加星哦!🌟


好了,今天的任务完成啦!希望这篇幽默风趣的翻译能让你轻松掌握如何用 FastAPI 构建 MCP 服务器。要是你觉得有用,记得给我点个赞哈!否则……嗯,你的工作可能就像气球一样飞走咯,说不定连你的家人都得跟着紧张一下下呢!😄

相关文章:

如何使用 FastAPI 构建 MCP 服务器

哎呀,各位算法界的小伙伴们!今天咱们要聊聊一个超酷的话题——MCP 协议!你可能已经听说了,Anthropic 推出了这个新玩意儿,目的是让 AI 代理和你的应用程序之间的对话变得更顺畅、更清晰。不过别担心,为你的…...

基于Python的Django框架的手机购物商城管理系统

标题:基于Python的Django框架的手机购物商城管理系统 内容:1.摘要 随着互联网的快速发展,手机购物逐渐成为人们日常生活中不可或缺的一部分。本研究的目的是开发一个基于Python的Django框架的手机购物商城管理系统,以提高购物商城的管理效率和用户体验。…...

【UE5.3.2】初学1:适合初学者的入门路线图和建议

3D人物的动作制作 大神分析:3D人物的动作制作通常可以分为以下几个步骤: 角色绑定(Rigging):将3D人物模型绑定到一个骨骼结构上,使得模型能够进行动画控制。 动画制作(Animation):通过控制骨骼结构,制作出人物的各种动作,例如走路、跳跃、打斗等。 动画编辑(Ani…...

当 EcuBus-Pro + UTA0401 遇上 NSUC1500

文章目录 1.前言2.EcuBus-Pro简介2.1 官方地址2.2 概览 3.纳芯微NSUC1500简介3.1 NSUC1500概述3.2 产品特性 4.测试环境5.基础功能5.1 数据发送5.2 数据监控 6.自动化功能6.1 脚本创建6.2 脚本编辑6.3 脚本编辑与测试 7.音乐律动7.1 导入例程7.2 效果展示 ECB工程 1.前言 最近…...

qml 中的anchors

理解 QML 中的 anchors(锚定) 在 QML 中,anchors 是一种强大的布局机制,用于相对于父元素或同级元素定位和调整组件大小。它比简单的 x/y 坐标定位更灵活,能够自动适应不同屏幕尺寸。 基本概念 在你的代码中&#x…...

【FreeRTOS】裸机开发与操作系统区别

🔎【博主简介】🔎 🏅CSDN博客专家 🏅2021年博客之星物联网与嵌入式开发TOP5 🏅2022年博客之星物联网与嵌入式开发TOP4 🏅2021年2022年C站百大博主 🏅华为云开发…...

Deepseek API+Python 测试用例一键生成与导出 V1.0.4 (接口文档生成接口测试用例保姆级教程)

接口文档生成接口测试用例保姆级教程 随着测试需求的复杂性增加,测试用例的设计和生成变得愈发重要。Deepseek API+Python 测试用例生成工具在 V1.0.4 中进行了全方位的优化和功能扩展,特别是对接口测试用例设计的支持和接口文档的智能解析处理。本文将详细介绍 V1.0.4 版本…...

CET-4增量表

CET-4词表-增量表 注: 【1】所谓增量,是相对于高中高考之增量 即,如果你是在读大学生,高中英语单词过关了,准备考CET-4,那么侧重下面的增量词表的学习,也算是一条捷径吧 ^_^ 【2】本结果数据 官…...

DeepSeek详解:探索下一代语言模型

文章目录 前言一、什么是DeepSeek二、DeepSeek核心技术2.1 Transformer架构2.1.1 自注意力机制 (Self-Attention Mechanism)(a) 核心思想(b) 计算过程(c) 代码实现 2.1.2 多头注意力 (Multi-Head Attention)(a) 核心思想(b) 工作原理(c) 数学描述(d) 代码实现 2.1.3 位置编码 (…...

深入解析主线程退出与子线程管理:何时 Join(),何时 Detach()?

在多线程编程中,主线程退出时如何正确管理子线程是一个关键问题。如果子线程没有 Join() 或 Detach(),不同的操作系统会有不同的行为,可能导致内存泄漏、资源竞争、甚至程序崩溃。本文将深入探讨主线程退出时子线程的管理策略,并提…...

AWS API Gateway Canary部署实战:Lambda到ECS的平滑迁移指南

在云原生架构中,如何实现服务平滑迁移是一个常见挑战。本文将详细介绍如何利用AWS API Gateway的Canary部署功能,实现从Lambda函数到ECS服务的无缝迁移,同时保证客户端无感知并提供便捷的回退机制。 一、迁移方案概述 在本方案中,我们将实现以下目标: 将现有Lambda服务平…...

Docker学习--容器操作相关命令--docker export 命令

docker export 命令的作用: 用于将 Docker 容器的文件系统导出为一个 tar 归档文件。主要用于备份或迁移容器的文件系统,而不包括 Docker 镜像的所有层和元数据。 语法: docker export [参数选项] CONTAINER(要操作的容器&#x…...

【Easylive】获取request对象的两种方式

【Easylive】项目常见问题解答(自用&持续更新中…) 汇总版 1. 通过方法参数直接注入(Spring MVC 推荐) 在 Controller 方法中直接声明 HttpServletRequest 参数,Spring 会自动注入当前请求的 request 对象&#…...

FOC 控制笔记【三】磁链观测器

一、磁链观测器基础 1.1 什么是磁链 磁链(magnetic linkage)是电磁学中的一个重要概念,指导电线圈或电流回路所链环的磁通量。单位为韦伯(Wb),又称磁通匝。 公式为: 线圈匝数 穿过单匝数的…...

SpringBoot项目读取自定义的配置文件

先说使用场景: 开发时在resource目录下新建一个 config 文件夹, 在里面存放 myconf.properties 文件, 打包后这个文件会放到与jar包同级的目录下, 如下图 关键点:自定义的文件名(当然后缀是.properties),自定义的存放路径。 主要的要求是在打包后运行过…...

UniApp快速表单组件

环境&#xff1a;vue3 uni-app 依赖库&#xff1a;uview-plus、dayjs 通过配置项快速构建 form 表单 使用 <script setup>import CustomCard from /components/custom-card.vue;import { ref } from vue;import CustomFormItem from /components/form/custom-form-it…...

在PyCharm 中免费集成Amazon CodeWhisperer

CodeWhisperer 是Amazon发布的一款免费的AI 编程辅助小工具&#xff0c;可在你的集成开发环境&#xff08;IDE&#xff09;中生成实时单行或全函数代码建议&#xff0c;帮助你快速构建软件。简单来说&#xff0c;Amazon CodeWhisperer就是你写一段注释&#xff08;支持中文&…...

语音克隆(Voice Cloning)

要将文字转化为“自己声音”的音频&#xff0c;需要用到语音克隆&#xff08;Voice Cloning&#xff09;技术。这种技术通常要求用户提供一定量的语音样本&#xff08;几分钟到几小时不等&#xff09;&#xff0c;然后通过 AI 模型生成与你声音相似的音频。目前市面上完全免费且…...

[7-02-02].第15节:生产经验 - 消费者相关操作

Kafka笔记大纲 五、生产经验——分区的分配以及再平衡: 4.1.生产经验——分区的分配以及再平衡 4.2.参数&#xff1a; 5.4.1 Range 以及再平衡...

Matlab_Simulink中导入CSV数据与仿真实现方法

前言 在Simulink仿真中&#xff0c;常需将外部数据&#xff08;如CSV文件或MATLAB工作空间变量&#xff09;作为输入信号驱动模型。本文介绍如何高效导入CSV数据至MATLAB工作空间&#xff0c;并通过From Workspace模块实现数据到Simulink的精确传输&#xff0c;适用于运动控制…...

vue3大屏适配

最近写大屏&#xff0c;发现适配真的好难统一&#xff0c;不是这有问题就是那有问题&#xff0c;要不然页面拉伸的就变形了&#xff0c;在网上找到了一个好用的插件&#xff0c;暂时用起来没问题&#xff0c;如果后续有问题或者大家有什么好的想法可以在评论区说一下。 插件 bi…...

文件操作与IO—File类

目录 1 属性 2 构造方法 3 常用方法 4 示例代码 1 属性 修饰符与类型 属性 含义 static String pathSeparator 依赖于系统的路径分隔符&#xff0c;String类型的表示 static char pathSeparator 依赖于系统的路径分隔符&#xff0c;char类型的表示 2 构造方法 构造…...

音频进阶学习二十四——IIR滤波器设计方法

文章目录 前言一、滤波器设计要求1.选频滤波器种类2.通带、阻带、过度带3.滤波器设计指标 二、IIR滤波器的设计过程1.设计方法2.常见的模拟滤波器设计1&#xff09;巴特沃斯滤波器&#xff08;Butterworth Filter&#xff09;2&#xff09;切比雪夫滤波器&#xff08;Chebyshev…...

OpenBMC:BmcWeb 处理http请求2 查找路由对象

OpenBMC:BmcWeb 处理http请求1 生成Request和AsyncResp对象_bmc web-CSDN博客 当接收到http请求,并且完成解析后,调用了App::handle处理请求 而App::handle又调用了router.handle(req, asyncResp);来处理请求 1.Router::handle void handle(const std::shared_ptr<Requ…...

MVC编程

MVC基本概述 例子——显示本地文件系统结构 先分别拖入ListView,TableView,TreeView 然后在进行布局 在widget.cpp 结果 mock测试 1&#xff0c;先加入json测试对象 2.创建后端目录 3&#xff0c;在src添加新文件 在models文件夹里 在mybucket.h,添加测试用例的三个字段 4.在…...

怎么对asp.web api进行单元测试?

在 ASP.NET Web API 中进行单元测试是一种确保代码质量和功能正确性的重要实践。单元测试的重点是针对 API 控制器中的逻辑进行测试&#xff0c;而不依赖于外部依赖&#xff08;如数据库、文件系统或网络请求&#xff09;。以下是实现 ASP.NET Web API 单元测试的步骤和方法&am…...

Qt进阶开发:对象树与拥有权

文章目录 一、对象树的概念二、对象拥有权&#xff08;Ownership&#xff09;三、Qt Widgets 中的特殊情况四、对象树与拥有权的实例 一、对象树的概念 在 Qt 中&#xff0c;对象树&#xff08;Object Tree&#xff09;与对象的拥有权&#xff08;Ownership&#xff09;密切相…...

Django:构建高性能Web应用

引言&#xff1a;为何选择Django&#xff1f; 在当今快速发展的互联网时代&#xff0c;Web应用的开发效率与可维护性成为开发者关注的核心。Django作为一款基于Python的高级Web框架&#xff0c;以其"开箱即用"的特性、强大的ORM系统、优雅的URL路由设计&#xff0c;…...

C语言基础系列【32】指针进阶5:指针与常量

博主介绍&#xff1a;程序喵大人 35- 资深C/C/Rust/Android/iOS客户端开发10年大厂工作经验嵌入式/人工智能/自动驾驶/音视频/游戏开发入门级选手《C20高级编程》《C23高级编程》等多本书籍著译者更多原创精品文章&#xff0c;首发gzh&#xff0c;见文末&#x1f447;&#x1f…...

TS 中 interface 和 type 详解

在 TypeScript 中&#xff0c;interface 和 type 都可以用来定义类型&#xff0c;但它们有一些关键的区别。以下是它们的详细对比&#xff1a; 1. 基本定义 interface 用于声明对象的形状&#xff08;属性和方法&#xff09;&#xff0c;是面向对象编程中“接口”概念的体现。 …...