一、简介
1.1 FastMCP
FastMCP 是构建 MCP 服务器和客户端的快速、Python 方式。
MCP:Model Context Protocol,是标准化的提供大语言模型上下文和工具的协议。
FastMCP 允许用户使用简单、符合直觉的方式构建 MCP 服务器和客户端。可以使用更简介、Python 风格的代码创建工具、暴露资源、定义提示词:
python
from fastmcp import FastMCP
mcp = FastMCP("Demo 🚀")
@mcp.tool()
def add(a: int, b: int) -> int:
"""Add two numbers"""
return a + b
if __name__ == "__main__":
mcp.run()
1.2 FastMCP 2.0 vs MCP 官方 SDK
官方 MCP 中 Python SDK 中存在 FastMCP,那是基于 FastMCP 1.0 的。
FastMCP 2.0在 1.0 的基础上进行了显著扩展,引入了强大的客户端功能、服务器代理与组合、OpenAPI/FastAPI 集成以及更多高级功能。
FastMCP 2.0 是构建现代、强大的 MCP 应用程序的推荐途径。
1.3 什么是MCP?
MCP 允许你构建服务器以安全、标准化的方式去暴露数据和工具给大语言模型。MCP 通常被描述为 "AI 的USB 接口",提供统一的方式去连接 LLMs 和资源。可以把它看作是专门为 LLM 交互的 API。MCP 服务器可以做:
- 通过 Resources 暴露数据(可以看作是一堆 GET 接口,用来加载信息给大模型上下文)
- 通过 Tools 提供工具(可以看作一堆 POST 接口,用来执行代码或产生一些作用)
- 通过 Prompts 定义提示词模板(可复用的模板)
二、安装
2.1 安装FastMCP
推荐使用 uv 安装和管理 FastMCP。
如果想在项目中使用 FastMCP,可以通过下面代码添加依赖:
bash
uv add fastmcp
或者可以用 pip 或者 uv pip 安装
bash
uv pip install fastmcp
2.1.1 验证安装
可以通过下面命令验证是否安装成功:
bash
fastmcp version
你应该会看到如下输出:
bash
% fastmcp version
FastMCP version: 2.3.4
MCP version: 1.8.1
Python version: 3.12.2
Platform: macOS-15.4.1-arm64-arm-64bit
FastMCP root path: /path/to/fastmcp
2.2 从官方SDK更新
从官方 SDK 的 FastMCP 1.0更新到 FastMCP 2.0 很简单。将导包从from mcp.server.fastmcp import FastMCP
改为from fastmcp import FastMCP
就可以了。
python
# 之前
# from mcp.server.fastmcp import FastMCP
# 现在
from fastmcp import FastMCP
mcp = FastMCP("My MCP Server")
三、快速开始
3.1 创建MCP服务器
一个MCP服务器就是工具、资源和其他MCP组件的集合。创建MCP服务器需要用到FastMCP类。
创建一个文件my_server.py
然后添加如下代码:
python
from fastmcp import FastMCP
mcp = FastMCP("My MCP Server")
这样就创建了一个MCP服务器了,下面来添加一些工具。
3.2 添加工具
下面添加一个打招呼的工具,编写一个函数,然后使用@mcp.tool装饰器:
python
from fastmcp import FastMCP
mcp = FastMCP("My MCP Server")
@mcp.tool()
def greet(name: str) -> str:
return f"Hello, {name}"
3.3 测试服务器
创建MCP客户端,并指向刚刚创建的服务器:
python
import asyncio
from fastmcp import FastMCP, Client
mcp = FastMCP("My MCP Server")
@mcp.tool()
def greet(name: str) -> str:
return f"Hello, {name}!"
client = Client(mcp)
async def call_tool(name: str):
async with client:
result = await client.call_tool("greet", {"name": name})
print(result)
asyncio.run(call_tool("Ford"))
这里需要注意几点:
- 客户端是异步的。
- 在使用客户端前,需要使用 async with client 进入客户端上下文,在一个客户端可以调用多次 call。
3.4 运行服务器
为了用 Python 运行 MCP 服务器,需要添加 run 语句在__main__
中:
python
from fastmcp import FastMCP
mcp = FastMCP("My MCP Server")
@mcp.tool()
def greet(name: str) -> str:
return f"Hello, {name}!"
if __name__ == "__main__":
mcp.run()
这样我们就可以使用python my_server.py
运行 MCP 服务器。
3.4.1 用Python与服务器交互
现在可以像和其他第三方 MCP 服务器一样进行交互。
创建客户端并指向服务器文件:
python
import asyncio
from fastmcp import Client
client = Client("my_server.py")
async def call_tool(name: str):
async with client:
result = await client.call_tool("greet", {"name": name})
print(result)
asyncio.run(call_tool("Ford"))