Install FastMCP

We recommend using uv to install and manage FastMCP.

If you plan to use FastMCP in your project, you can add it as a dependency with:

uv add fastmcp

Alternatively, you can install it directly with pip or uv pip:

uv pip install fastmcp

Verify Installation

To verify that FastMCP is installed correctly, you can run the following command:

fastmcp version

You should see output like the following:

$ fastmcp version

FastMCP version:   0.4.2.dev41+ga077727.d20250410
MCP version:                                1.6.0
Python version:                            3.12.2
Platform:            macOS-15.3.1-arm64-arm-64bit
FastMCP root path:            ~/Developer/fastmcp

Upgrading from the Official MCP SDK

Upgrading from the official MCP SDK’s FastMCP 1.0 to FastMCP 2.0 is generally straightforward. The core server API is highly compatible, and in many cases, changing your import statement from from mcp.server.fastmcp import FastMCP to from fastmcp import FastMCP will be sufficient.

# Before
# from mcp.server.fastmcp import FastMCP

# After
from fastmcp import FastMCP

mcp = FastMCP("My MCP Server")

Prior to fastmcp==2.3.0 and mcp==1.8.0, the 2.x API always mirrored the 1.0 API. However, as the projects diverge, this can not be guaranteed. You may see deprecation warnings if you attempt to use 1.0 APIs in FastMCP 2.x. Please refer to this documentation for details on new capabilities.

Versioning and Breaking Changes

While we make every effort not to introduce backwards-incompatible changes to our public APIs and behavior, FastMCP exists in a rapidly evolving MCP landscape. We’re committed to bringing the most cutting-edge features to our users, which occasionally necessitates changes to existing functionality.

As a practice, breaking changes will only occur on minor version changes (e.g., 2.3.x to 2.4.0). A minor version change indicates either:

  • A significant new feature set that warrants a new minor version
  • Introducing breaking changes that may affect behavior on upgrade

For users concerned about stability in production environments, we recommend pinning FastMCP to a specific version in your dependencies.

Whenever possible, FastMCP will issue deprecation warnings when users attempt to use APIs that are either deprecated or destined for future removal. These warnings will be maintained for at least 1 minor version release, and may be maintained longer.

Note that the “public API” includes the core functionality of the FastMCP server and its methods. It does not include private methods or objects that are stored as private attributes, as we do not expect users to rely on those implementation details.

Installing for Development

If you plan to contribute to FastMCP, you should begin by cloning the repository and using uv to install all dependencies (development dependencies are installed automatically):

git clone https://github.com/jlowin/fastmcp.git
cd fastmcp
uv sync

This will install all dependencies, including ones for development, and create a virtual environment, which you can activate and use as normal.

Unit Tests

FastMCP has a comprehensive unit test suite, and all PR’s must introduce and pass appropriate tests. To run the tests, use pytest:

pytest

Pre-Commit Hooks

FastMCP uses pre-commit to manage code quality, including formatting, linting, and type-safety. All PRs must pass the pre-commit hooks, which are run as a part of the CI process. To install the pre-commit hooks, run:

uv run pre-commit install

Alternatively, to run pre-commit manually at any time, use:

pre-commit run --all-files