MCP Python SDK
The Model Context Protocol (MCP) allows applications to provide context for LLMs in a standardized way, separating the concerns of providing context from the actual LLM interaction.
This Python SDK implements the full MCP specification, making it easy to:
- Build MCP servers that expose resources, prompts, and tools
- Create MCP clients that can connect to any MCP server
- Use standard transports like stdio, SSE, and Streamable HTTP
If you want to read more about the specification, please visit the MCP documentation.
Quick Example
Here's a simple MCP server that exposes a tool, resource, and prompt:
server.py
from mcp.server.fastmcp import FastMCP mcp = FastMCP("Test Server") @mcp.tool() def add(a: int, b: int) -> int: """Add two numbers""" return a + b @mcp.resource("greeting://{name}") def get_greeting(name: str) -> str: """Get a personalized greeting""" return f"Hello, {name}!" @mcp.prompt() def greet_user(name: str, style: str = "friendly") -> str: """Generate a greeting prompt""" return f"Write a {style} greeting for someone named {name}." Test it with the MCP Inspector:
uv run mcp dev server.py Getting Started
- Install the MCP SDK
- Learn concepts - understand the three primitives and architecture
- Explore authorization - add security to your servers
- Use low-level APIs - for advanced customization
API Reference
Full API documentation is available in the API Reference.