Programmatic client for interacting with MCP servers through a well-typed, Pythonic interface.
New in version 2.0.0The fastmcp.Client class provides a programmatic interface for interacting with any MCP server. It handles protocol details and connection management automatically, letting you focus on the operations you want to perform.The FastMCP Client is designed for deterministic, controlled interactions rather than autonomous behavior, making it ideal for testing MCP servers during development, building deterministic applications that need reliable MCP interactions, and creating the foundation for agentic or LLM-based clients with structured, type-safe operations.
This is a programmatic client that requires explicit function calls and provides direct control over all MCP operations. Use it as a building block for higher-level systems.
The client automatically selects a transport based on what you pass to it, but different transports have different characteristics that matter for your use case.In-memory transport connects directly to a FastMCP server instance within the same Python process. Use this for testing and development where you want to eliminate subprocess and network complexity. The server shares your process’s environment and memory space.
Copy
from fastmcp import Client, FastMCPserver = FastMCP("TestServer")client = Client(server) # In-memory, no network or subprocess
STDIO transport launches a server as a subprocess and communicates through stdin/stdout pipes. This is the standard mechanism used by desktop clients like Claude Desktop. The subprocess runs in an isolated environment, so you must explicitly pass any environment variables the server needs.
Copy
from fastmcp import Client# Simple inference from file pathclient = Client("my_server.py")# With explicit environment configurationclient = Client("my_server.py", env={"API_KEY": "secret"})
HTTP transport connects to servers running as web services. Use this for production deployments where the server runs independently and manages its own lifecycle.
Copy
from fastmcp import Clientclient = Client("https://api.example.com/mcp")
See Transports for detailed configuration options including authentication headers, session persistence, and multi-server configurations.
New in version 2.4.0Create clients from MCP configuration dictionaries, which can include multiple servers. While there is no official standard for MCP configuration format, FastMCP follows established conventions used by tools like Claude Desktop.
Copy
config = { "mcpServers": { "weather": { "url": "https://weather-api.example.com/mcp" }, "assistant": { "command": "python", "args": ["./assistant_server.py"] } }}client = Client(config)async with client: # Tools are prefixed with server names weather_data = await client.call_tool("weather_get_forecast", {"city": "London"}) response = await client.call_tool("assistant_answer_question", {"question": "What's the capital of France?"}) # Resources use prefixed URIs icons = await client.read_resource("weather://weather/icons/sunny")
The client uses context managers for connection management. When you enter the context, the client establishes a connection and performs an MCP initialization handshake with the server. This handshake exchanges capabilities, server metadata, and instructions.
Copy
from fastmcp import Client, FastMCPmcp = FastMCP(name="MyServer", instructions="Use the greet tool to say hello!")@mcp.tooldef greet(name: str) -> str: """Greet a user by name.""" return f"Hello, {name}!"async with Client(mcp) as client: # Initialization already happened automatically print(f"Server: {client.initialize_result.serverInfo.name}") print(f"Instructions: {client.initialize_result.instructions}") print(f"Capabilities: {client.initialize_result.capabilities.tools}")
For advanced scenarios where you need precise control over when initialization happens, disable automatic initialization and call initialize() manually:
Copy
from fastmcp import Clientclient = Client("my_mcp_server.py", auto_initialize=False)async with client: # Connection established, but not initialized yet print(f"Connected: {client.is_connected()}") print(f"Initialized: {client.initialize_result is not None}") # False # Initialize manually with custom timeout result = await client.initialize(timeout=10.0) print(f"Server: {result.serverInfo.name}") # Now ready for operations tools = await client.list_tools()
FastMCP clients interact with three types of server components.Tools are server-side functions that the client can execute with arguments. Call them with call_tool() and receive structured results.
Copy
async with client: tools = await client.list_tools() result = await client.call_tool("multiply", {"a": 5, "b": 3}) print(result.data) # 15
See Tools for detailed documentation including version selection, error handling, and structured output.Resources are data sources that the client can read, either static or templated. Access them with read_resource() using URIs.
See Resources for detailed documentation including templates and binary content.Prompts are reusable message templates that can accept arguments. Retrieve rendered prompts with get_prompt().
The FastMCP Client is designed as a foundational tool. Use it directly for deterministic operations, or build higher-level agentic systems on top of its reliable, type-safe interface.