fastmcpp is a C++ port of the Python fastmcp library, providing native performance for MCP servers and clients with support for tools, resources, prompts, and multiple transport layers (STDIO, HTTP/SSE, WebSocket).
Status: Beta – core MCP features track the Python fastmcp reference.
Current version: 2.14.0
Features
- Core MCP protocol implementation (JSON‑RPC).
- Multiple transports: STDIO, HTTP (SSE), Streamable HTTP, WebSocket.
- Streamable HTTP transport (MCP spec 2025-03-26) with session management.
- Tool management and invocation.
- Resources and prompts support.
- Resource templates with URI pattern matching.
- JSON Schema validation.
- FastMCP high-level application class.
- ProxyApp for backend server proxying.
- ServerSession for bidirectional communication, sampling, and server-initiated notifications.
- Built-in middleware: Logging, Timing, Caching, RateLimiting, ErrorHandling.
- Tool transforms for input/output processing.
- Integration with MCP‑compatible CLI tools.
- Cross‑platform: Windows, Linux, macOS.
Requirements
- C++17 or later compiler.
- CMake 3.20 or higher.
nlohmann/json(fetched automatically).
Optional:
- libcurl (for HTTP POST streaming).
- cpp‑httplib (HTTP server, fetched automatically).
- easywsclient (WebSocket client, fetched automatically).
Building
Basic build
git clone https://github.com/0xeb/fastmcpp.git cd fastmcpp cmake -B build -S . -DCMAKE_BUILD_TYPE=Release cmake --build build --config Release -j
Recommended configuration options
cmake -B build -S . \
-DCMAKE_BUILD_TYPE=Release \
-DFASTMCPP_ENABLE_POST_STREAMING=ON \
-DFASTMCPP_FETCH_CURL=ON \
-DFASTMCPP_ENABLE_STREAMING_TESTS=ON \
-DFASTMCPP_ENABLE_WS_STREAMING_TESTS=ONKey options:
| Option | Default | Description |
|---|---|---|
CMAKE_BUILD_TYPE |
Debug | Build configuration (Debug/Release/RelWithDebInfo) |
FASTMCPP_ENABLE_POST_STREAMING |
OFF | Enable HTTP POST streaming (requires libcurl) |
FASTMCPP_FETCH_CURL |
OFF | Fetch and build curl if not found |
FASTMCPP_ENABLE_STREAMING_TESTS |
OFF | Enable SSE streaming tests |
FASTMCPP_ENABLE_WS_STREAMING_TESTS |
OFF | Enable WebSocket streaming tests |
Platform notes
Windows (Visual Studio):
cmake -B build -S . -G "Visual Studio 17 2022" cmake --build build --config Release
Linux/macOS:
cmake -B build -S . -DCMAKE_BUILD_TYPE=Release cmake --build build -j"$(nproc)"
Testing
# Run all tests ctest --test-dir build -C Release --output-on-failure # Parallel ctest --test-dir build -C Release -j4 --output-on-failure # Run a specific test ctest --test-dir build -C Release -R fastmcp_smoke --output-on-failure # List tests ctest --test-dir build -C Release -N
Basic Usage
STDIO MCP server
#include <fastmcpp/tools/manager.hpp> #include <fastmcpp/mcp/handler.hpp> #include <fastmcpp/server/stdio_server.hpp> int main() { fastmcpp::tools::ToolManager tm; // register tools on tm... auto handler = fastmcpp::mcp::make_mcp_handler( "myserver", "1.0.0", tm ); fastmcpp::server::StdioServerWrapper server(handler); server.run(); // blocking return 0; }
HTTP server
#include <fastmcpp/server/server.hpp> #include <fastmcpp/server/http_server.hpp> int main() { auto srv = std::make_shared<fastmcpp::server::Server>(); srv->register_get("/health", [](const nlohmann::json&) { return nlohmann::json{{"status", "ok"}}; }); fastmcpp::server::HttpServerWrapper http(srv, "127.0.0.1", 8080); http.start(); // non‑blocking std::this_thread::sleep_for(std::chrono::hours(1)); http.stop(); return 0; }
HTTP client
#include <fastmcpp/client/client.hpp> #include <fastmcpp/client/transports.hpp> int main() { auto transport = std::make_shared<fastmcpp::client::HttpTransport>( "http://localhost:8080" ); fastmcpp::client::Client client(transport); auto response = client.call("tool/invoke", { {"name", "calculator"}, {"input", {{"operation", "add"}, {"a", 5}, {"b", 3}}} }); std::cout << response.dump() << std::endl; return 0; }
Streamable HTTP server (MCP spec 2025-03-26)
#include <fastmcpp/tools/manager.hpp> #include <fastmcpp/mcp/handler.hpp> #include <fastmcpp/server/streamable_http_server.hpp> int main() { fastmcpp::tools::ToolManager tm; // register tools on tm... auto handler = fastmcpp::mcp::make_mcp_handler( "myserver", "1.0.0", tm ); // Streamable HTTP server on /mcp endpoint fastmcpp::server::StreamableHttpServerWrapper server( handler, "127.0.0.1", 8080, "/mcp" ); server.start(); // non-blocking std::this_thread::sleep_for(std::chrono::hours(1)); server.stop(); return 0; }
Streamable HTTP client
#include <fastmcpp/client/transports.hpp> int main() { fastmcpp::client::StreamableHttpTransport transport( "http://localhost:8080", "/mcp" ); // Send initialize request auto init_response = transport.request("mcp", { {"jsonrpc", "2.0"}, {"id", 1}, {"method", "initialize"}, {"params", { {"protocolVersion", "2024-11-05"}, {"capabilities", {}}, {"clientInfo", {{"name", "client"}, {"version", "1.0"}}} }} }); // Session ID is automatically managed via Mcp-Session-Id header std::cout << "Session: " << transport.session_id() << std::endl; return 0; }
Examples
See the examples/ directory for complete programs, including:
stdio_server.cpp– STDIO MCP server.server_quickstart.cpp– HTTP server with routes.client_quickstart.cpp– HTTP client usage.tool_example.cpp– tool registration and invocation.middleware_example.cpp– request/response middleware.
Project Structure
fastmcpp/
include/fastmcpp/ # Public headers (client, server, tools, etc.)
src/ # Implementation
tests/ # Test suite (GoogleTest)
examples/ # Example programs
CMakeLists.txt # Build configuration
LICENSE # Apache 2.0 license
NOTICE # Attribution notices
README.md # This file
Contributing
Contributions are welcome. Please:
- Ensure all tests pass.
- Follow the existing code style.
- Add tests for new features.
- Update documentation as needed.
License
Copyright 2025 Elias Bachaalany
Licensed under the Apache License 2.0. See LICENSE and NOTICE for details.
This is a C++ port of fastmcp by Jeremiah Lowin. The Python library is the canonical implementation; fastmcpp aims to match its behavior for core features.
Support
For issues and questions, use the GitHub issue tracker: https://github.com/0xeb/fastmcpp/issues.
