Skip to main content

Progressive tool discovery gateway for MCP, built on FastMCP

Project description

fastmcp-gateway

PyPI Python License CI

Progressive tool discovery gateway for MCP. Aggregates tools from multiple upstream MCP servers and exposes them through 3 meta-tools, enabling LLMs to discover and use hundreds of tools without loading all schemas upfront.

LLM
 │
 └── fastmcp-gateway (3 meta-tools)
       ├── discover_tools    → browse domains and tools
       ├── get_tool_schema   → get parameter schema for a tool
       └── execute_tool      → run any discovered tool
             ├── apollo      (upstream MCP server)
             ├── hubspot     (upstream MCP server)
             ├── slack       (upstream MCP server)
             └── ...

Why?

When an LLM connects to many MCP servers, it receives all tool schemas at once. With 100+ tools, context windows fill up and tool selection accuracy drops. fastmcp-gateway solves this with progressive discovery: the LLM starts with 3 meta-tools and loads individual schemas on demand.

Install

pip install fastmcp-gateway

Quick Start

Python API

import asyncio
from fastmcp_gateway import GatewayServer

gateway = GatewayServer({
    "apollo": "http://apollo-mcp:8080/mcp",
    "hubspot": "http://hubspot-mcp:8080/mcp",
})

async def main():
    await gateway.populate()     # Discover tools from upstreams
    gateway.run(transport="streamable-http", port=8080)

asyncio.run(main())

CLI

export GATEWAY_UPSTREAMS='{"apollo": "http://apollo-mcp:8080/mcp", "hubspot": "http://hubspot-mcp:8080/mcp"}'
python -m fastmcp_gateway

The gateway starts on http://0.0.0.0:8080/mcp and exposes 3 tools to any MCP client.

How It Works

  1. discover_tools() — Call with no arguments to see all domains and tool counts. Call with domain="apollo" to see that domain's tools with descriptions.

  2. get_tool_schema("apollo_people_search") — Returns the full JSON Schema for a tool's parameters. Supports fuzzy matching.

  3. execute_tool("apollo_people_search", {"query": "Anthropic"}) — Routes the call to the correct upstream server and returns the result.

LLMs learn the workflow from the gateway's built-in system instructions and only load schemas for tools they actually need.

Configuration

All configuration is via environment variables:

Variable Required Default Description
GATEWAY_UPSTREAMS Yes JSON object: {"domain": "url", ...}
GATEWAY_NAME No fastmcp-gateway Server name
GATEWAY_HOST No 0.0.0.0 Bind address
GATEWAY_PORT No 8080 Bind port
GATEWAY_INSTRUCTIONS No Built-in Custom LLM system instructions
GATEWAY_REGISTRY_AUTH_TOKEN No Bearer token for upstream discovery
GATEWAY_DOMAIN_DESCRIPTIONS No JSON object: {"domain": "description", ...}
GATEWAY_UPSTREAM_HEADERS No JSON object: {"domain": {"Header": "Value"}, ...}
LOG_LEVEL No INFO Logging level

Per-Upstream Auth

If your upstream servers require different authentication, use GATEWAY_UPSTREAM_HEADERS to set per-domain headers:

export GATEWAY_UPSTREAM_HEADERS='{"ahrefs": {"Authorization": "Bearer sk-xxx"}}'

Domains without overrides use request passthrough (headers from the incoming MCP request are forwarded to the upstream).

Health Endpoints

The gateway exposes Kubernetes-compatible health checks:

  • GET /healthz — Liveness probe. Always returns 200.
  • GET /readyz — Readiness probe. Returns 200 if tools are populated, 503 otherwise.

Docker & Kubernetes

See examples/kubernetes/ for a ready-to-use Dockerfile and Kubernetes manifests.

# Build
docker build -f examples/kubernetes/Dockerfile -t fastmcp-gateway .

# Run
docker run -e GATEWAY_UPSTREAMS='{"svc": "http://host.docker.internal:8080/mcp"}' \
  -p 8080:8080 fastmcp-gateway

Contributing

See CONTRIBUTING.md for development setup, architecture overview, and guidelines.

License

Apache License 2.0. See LICENSE.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

fastmcp_gateway-0.1.1.tar.gz (33.0 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

fastmcp_gateway-0.1.1-py3-none-any.whl (19.2 kB view details)

Uploaded Python 3

File details

Details for the file fastmcp_gateway-0.1.1.tar.gz.

File metadata

  • Download URL: fastmcp_gateway-0.1.1.tar.gz
  • Upload date:
  • Size: 33.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for fastmcp_gateway-0.1.1.tar.gz
Algorithm Hash digest
SHA256 611ca9647391c5a71067796dbf04f40e4eb3d00f05023908170e23e6723c468d
MD5 1926a7f4cd27311120e41034053798c3
BLAKE2b-256 1ec83d0dfb15efb40c0ccdd0d365c90d1c1e6e28f9d94ac5a2169356a06a1ec7

See more details on using hashes here.

Provenance

The following attestation bundles were made for fastmcp_gateway-0.1.1.tar.gz:

Publisher: publish.yml on Ultrathink-Solutions/fastmcp-gateway

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file fastmcp_gateway-0.1.1-py3-none-any.whl.

File metadata

File hashes

Hashes for fastmcp_gateway-0.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 e31aacd7aeac9a848f1a8170657729e02231663ee32e300cfd8119111b905a23
MD5 a406474f2206b0d4e4d3f6e96b692607
BLAKE2b-256 78a03ae213523e503b96ac3af5ac4b7ffa4a43b26c02f78c118b4151b61b8eab

See more details on using hashes here.

Provenance

The following attestation bundles were made for fastmcp_gateway-0.1.1-py3-none-any.whl:

Publisher: publish.yml on Ultrathink-Solutions/fastmcp-gateway

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page