Claude Desktop
Call FastMCP servers from Claude Desktop
Claude Desktop supports MCP servers through local STDIO connections, allowing you to extend Claude’s capabilities with custom tools, resources, and prompts from your FastMCP servers.
This guide focuses specifically on using FastMCP servers with Claude Desktop. For general Claude Desktop MCP setup and official examples, see the official Claude Desktop quickstart guide.
Requirements
Claude Desktop requires MCP servers to run locally using STDIO transport. This means your server will communicate with Claude through standard input/output rather than HTTP.
If you need to connect to remote servers, you can create a proxy server that runs locally via STDIO and forwards requests to remote HTTP servers. See the Proxy Servers section below.
Create a Server
The examples in this guide will use the following simple dice-rolling server, saved as server.py
.
Install the Server
FastMCP CLI
The easiest way to install a FastMCP server in Claude Desktop is using the fastmcp install
command. This automatically handles the configuration and dependency management.
The install command supports the same file.py:object
notation as the run
command. If no object is specified, it will automatically look for a FastMCP server object named mcp
, server
, or app
in your file:
After installation, restart Claude Desktop completely. You should see a hammer icon (🔨) in the bottom left of the input box, indicating that MCP tools are available.
Dependencies
If your server has dependencies, include them with the --with
flag:
Alternatively, you can specify dependencies directly in your server code:
Environment Variables
Claude Desktop runs servers in a completely isolated environment with no access to your shell environment or locally installed applications. You must explicitly pass any environment variables your server needs.
If your server needs environment variables (like API keys), you must include them:
Or load them from a .env
file:
uv
must be installed and available in your system PATH. Claude Desktop runs in its own isolated environment and needsuv
to manage dependencies.- On macOS, it is recommended to install
uv
globally with Homebrew so that Claude Desktop will detect it:brew install uv
. Installinguv
with other methods may not make it accessible to Claude Desktop.
Manual Configuration
For more control over the configuration, you can manually edit Claude Desktop’s configuration file. You can open the configuration file from Claude’s developer settings, or find it in the following locations:
- macOS:
~/Library/Application Support/Claude/claude_desktop_config.json
- Windows:
%APPDATA%\Claude\claude_desktop_config.json
The configuration file is a JSON object with a mcpServers
key, which contains the configuration for each MCP server.
After updating the configuration file, restart Claude Desktop completely. Look for the hammer icon (🔨) to confirm your server is loaded.
Dependencies
If your server has dependencies, you can use uv
or another package manager to set up the environment.
uv
must be installed and available in your system PATH. Claude Desktop runs in its own isolated environment and needsuv
to manage dependencies.- On macOS, it is recommended to install
uv
globally with Homebrew so that Claude Desktop will detect it:brew install uv
. Installinguv
with other methods may not make it accessible to Claude Desktop.
Environment Variables
You can also specify environment variables in the configuration:
Claude Desktop runs servers in a completely isolated environment with no access to your shell environment or locally installed applications. You must explicitly pass any environment variables your server needs.
Remote Servers
Claude Desktop only supports local STDIO servers, but FastMCP can create a proxy server that forwards requests to a remote HTTP server. You can install the proxy server in Claude Desktop.
Create a proxy server that connects to a remote HTTP server:
Authentication
For authenticated remote servers, create an authenticated client following the guidance in the client auth documentation and pass it to the proxy: