跳到主要内容
极客日志极客日志面向AI+效率的开发者社区
首页博客GitHub 精选镜像工具UI配色美学隐私政策关于联系
搜索内容 / 工具 / 仓库 / 镜像...⌘K搜索
注册
博客列表
PythonAI

基于 FastAPI 自动构建 SSE MCP 服务器

基于 FastAPI 构建支持 SSE 协议的 MCP 服务器。利用 fastapi-mcp 库实现零配置集成,将 FastAPI 端点自动转换为 MCP 工具。涵盖依赖安装、代码示例、调试流程及 mcp-proxy 配置,展示如何利用异步编程处理高并发请求,实现大模型与外部系统的实时交互。FastAPI 通过类型安全的异步接口,将企业现有能力快速转化为大模型可调用的标准化服务,结合 Docker 和 Kubernetes 实现弹性伸缩部署。

ServerBase发布于 2026/2/6更新于 2026/5/312.3K 浏览
基于 FastAPI 自动构建 SSE MCP 服务器

本文将介绍如何使用 FastAPI 构建 MCP 服务器。Anthropic 推出的 MCP 协议旨在让 AI 代理与应用程序之间的对话更顺畅、清晰。FastAPI 基于 Starlette 和 Uvicorn,采用异步编程模型,可轻松处理高并发请求,尤其适合 MCP 场景下大模型与外部系统的实时交互需求,其性能接近 Node.js 和 Go,在数据库查询、文件操作等 I/O 密集型任务中表现卓越。

文章配图

FastAPI 基础知识

安装依赖
pip install uvicorn fastapi
FastAPI 服务代码示例
from fastapi import FastAPI

app = FastAPI()

@app.get("/")
async def root():
    return {"data": "Hello MCP!"}
uvicorn 启动 server
uvicorn server:app --reload

接下来,我们将基于 FastAPI 来开发 MCP 服务器。

文章配图

FastAPI 开发 MCP Server

FastAPI-MCP 是一个零配置工具,用于自动将 FastAPI 端点暴露为模型上下文协议(MCP)工具。其特点在于简洁性和高效性,主要特点如下:

  • 直接集成:不需要复杂的设置,直接集成到 FastAPI 应用中。
  • 自动转换:无需手动编写代码,自动将 FastAPI 端点转换为 MCP 工具。
  • 灵活性:支持自定义 MCP 工具,与自动生成的工具一同使用。
  • 性能:基于 Python 3.10+ 和 FastAPI,保证了高性能的 API 服务。
  • 文档友好:保持了原有的 API 文档,方便开发者使用和理解。
安装依赖
pip install fastapi-mcp
MCP 服务代码示例
from fastapi import FastAPI
from fastapi_mcp import add_mcp_server
from typing import Any
import httpx

# 常量
NWS_API_BASE = "https://api.weather.gov"
USER_AGENT = "weather-app/1.0"

app = FastAPI()
mcp_server = add_mcp_server(
    app,
    mount_path="/mcp",
    name="Weather MCP Server",
    describe_all_responses=True,
    describe_full_response_schema=True
)

async def make_nws_request(url: str) -> dict[str, Any] | None:
    """向 NWS API 发起请求,并进行错误处理。"""
    headers = {
        "User-Agent": USER_AGENT,
        "Accept": "application/geo+json"
    }
    async with httpx.AsyncClient() as client:
        try:
            response = await client.get(url, headers=headers, timeout=30.0)
            response.raise_for_status()
            return response.json()
        except Exception:
            return None

@mcp_server.tool()
async def get_forecast(latitude: float, longitude: float) -> str:
    """获取地点的天气预报。
    参数:
        latitude: 地点的纬度
        longitude: 地点的经度
    """
    points_url = f"{NWS_API_BASE}/points/{latitude},{longitude}"
    points_data = await make_nws_request(points_url)
    if not points_data:
        return "Unable to fetch forecast data for this location."
    forecast_url = points_data["properties"]["forecast"]
    forecast_data = await make_nws_request(forecast_url)
    if not forecast_data:
        return "Unable to fetch detailed forecast."
    periods = forecast_data["properties"]["periods"]
    forecasts = []
    for period in periods[:5]:
        forecast = f"""
        {period['name']}: Temperature: {period['temperature']}°{period['temperatureUnit']} Wind: {period['windSpeed']} {period['windDirection']} Forecast: {period['detailedForecast']}
        """
        forecasts.append(forecast)
    return "\n---\n".join(forecasts)
启动 mcp server
uvicorn server:app --host 0.0.0.0 --port 8001 --reload

文章配图

启动 mcp inspector 调试
CLIENT_PORT=8081 SERVER_PORT=8082 npx -y @modelcontextprotocol/inspector

文章配图

当集成了 MCP 的 FastAPI 应用运行起来后,可以用任何支持 SSE 的 MCP 客户端连接它。这里使用 mcp inspector 进行调试,通过 SSE 连接 Weather MCP 服务器。

SSE 是一种单向通信的模式,所以它需要配合 HTTP Post 来实现客户端与服务端的双向通信。严格的说,这是一种 HTTP Post(客户端->服务端) + HTTP SSE(服务端->客户端)的伪双工通信模式,区别于 WebSocket 双向通信。

文章配图

如果 MCP 客户端不支持 SSE,可以使用 mcp-proxy 连接 MCP 服务器。本质上是本地通过 stdio 连接到 mcp-proxy,再由 mcp-proxy 通过 SSE 连接到 MCP Server 上。

mcp-proxy 支持两种模式,stdio to SSE 和 SSE to stdio。

文章配图

安装 mcp-proxy

uv tool install mcp-proxy

配置 claude_desktop_config.json

{
  "mcpServers": {
    "weather-api-mcp-proxy": {
      "command": "mcp-proxy",
      "args": ["http://127.0.0.1:8001/mcp"]
    }
  }
}

FastAPI-MCP 目前还有很多功能不完善,我们将持续关注进展。后续版本将支持更灵活的自动挂载功能,并基于现有 fastapi base_url 将 api 挂载至 mcp_server。

大模型基建工程总结

FastAPI 构建 MCP 服务器的核心价值在于:通过类型安全的异步接口,将企业现有能力快速转化为大模型可调用的标准化服务。这种架构既保留了 FastAPI 的高效开发体验,又通过 MCP 协议实现了与前沿 AI 技术的无缝对接,同时结合 Docker 和 Kubernetes 实现弹性伸缩部署,可以快速应对大模型调用量的突发增长,是构建下一代智能系统的理想选择。

目录

  1. FastAPI 基础知识
  2. 安装依赖
  3. FastAPI 服务代码示例
  4. uvicorn 启动 server
  5. FastAPI 开发 MCP Server
  6. 安装依赖
  7. MCP 服务代码示例
  8. 常量
  9. 启动 mcp server
  10. 启动 mcp inspector 调试
  11. 大模型基建工程总结
  • 💰 8折买阿里云服务器限时8折了解详情
  • Magick API 一键接入全球大模型注册送1000万token查看
  • 🤖 一键搭建Deepseek满血版了解详情
  • 一键打造专属AI 智能体了解详情
极客日志微信公众号二维码

微信扫一扫,关注极客日志

微信公众号「极客日志V2」,在微信中扫描左侧二维码关注。展示文案:极客日志V2 zeeklog

更多推荐文章

查看全部
  • noteDigger 纯前端音频扒谱工具技术解析
  • QTTabBar 为 Windows 资源管理器添加标签页功能
  • Meta AI 前首席科学家 LeCun 承认 Llama 4 基准测试存在操纵
  • C/C++ 中 extern 关键字详解:函数与变量修饰
  • LLaMA 大模型开源论文阅读笔记
  • 深入解析 VR 与 AR:从技术原理到未来图景
  • 基于 Llama-Factory 的盘古大模型轻量化训练方案
  • RTD1296PB 与 RK3568:NAS 与智能家居芯片选型实战对比
  • AI 写作辅助平台深度评测:炼字工坊与蛙蛙写作
  • JeecgBoot 在线代码编辑器功能与集成指南
  • 聪明的人已经发现,26年的前端不对劲了!
  • Java 动态构建 GeoJSON 完整实现指南
  • Linux 系统安装、故障排除、权限管理与安全配置指南
  • 本地部署 LLaMA-Factory 全指南
  • 二叉树深度求解与中后序转先序实战
  • Java 中精准获取毫秒级时间戳的方法与最佳实践
  • VSCode Git 工作树自动化管理与高效开发实践
  • C++ 类与对象的内在机制:构造函数与析构函数
  • Xilinx Vivado FPGA 开发工具安装教程:官网下载与配置指南
  • 2026 GitHub 热门 Python 项目:AI 代理与数据工具精选

相关免费在线工具

  • RSA密钥对生成器

    生成新的随机RSA私钥和公钥pem证书。 在线工具,RSA密钥对生成器在线工具,online

  • Mermaid 预览与可视化编辑

    基于 Mermaid.js 实时预览流程图、时序图等图表,支持源码编辑与即时渲染。 在线工具,Mermaid 预览与可视化编辑在线工具,online

  • 随机西班牙地址生成器

    随机生成西班牙地址(支持马德里、加泰罗尼亚、安达卢西亚、瓦伦西亚筛选),支持数量快捷选择、显示全部与下载。 在线工具,随机西班牙地址生成器在线工具,online

  • curl 转代码

    解析常见 curl 参数并生成 fetch、axios、PHP curl 或 Python requests 示例代码。 在线工具,curl 转代码在线工具,online

  • Base64 字符串编码/解码

    将字符串编码和解码为其 Base64 格式表示形式即可。 在线工具,Base64 字符串编码/解码在线工具,online

  • Base64 文件转换器

    将字符串、文件或图像转换为其 Base64 表示形式。 在线工具,Base64 文件转换器在线工具,online