MCP ExplorerExplorer

Central Mcp Proxy

@odgrimon a year ago
2 MPL-2.0
FreeCommunity
AI Systems
Centralize mcp server to run on a home lab instead of individually on every machine.

Overview

What is Central Mcp Proxy

central-mcp-proxy is a centralized hosting environment for Model Context Protocol (MCP) servers, designed to run on a home lab using Docker, Traefik, and SuperGateway. It allows multiple MCP servers to be managed from a single location instead of running them individually on separate machines.

Use cases

Use cases include managing project notes with Memory Bank, tracking issues and pull requests in GitHub, managing tasks in Linear, and interacting with Notion databases, all from a centralized interface.

How to use

To use central-mcp-proxy, clone the repository, copy the .env.example file to .env, fill in your API tokens, and start the services using Docker Compose with the command ‘docker compose up -d’. You can also start specific services using profiles.

Key features

Key features include a modular Docker Compose structure for easy service management, path-based routing via Traefik for efficient request handling, and SuperGateway for converting between stdio and SSE transports, enabling seamless communication between MCP servers and clients.

Where to use

central-mcp-proxy can be used in various fields such as software development, project management, and collaborative environments where integration with tools like Notion, GitHub, and Linear is required.

Content

Central MCP Host

This project provides a centralized hosting environment for Model Context Protocol (MCP) servers using Docker, Traefik, and SuperGateway.

Overview

This setup runs a Traefik reverse proxy to route requests to various MCP servers. SuperGateway is used to convert between stdio and SSE transports, allowing the MCP servers to communicate with clients using SSE.

MCP Servers Included

  • Notion: Interact with Notion databases and pages
  • Linear: Interact with Linear Tickets
  • GitHub: Interact with GitHub repositories, issues, and pull requests
  • Memory Bank: Tools for recording project notes, thought trails and learnings

Prerequisites

  • Docker and Docker Compose
  • Notion API token
  • Linear API token
  • GitHub API token

Setup

  1. Clone this repository
  2. Copy the .env.example file to .env and fill in your API tokens:
    cp .env.example .env
    # Edit .env with your API tokens
    
  3. Start the services:
    docker compose up -d
    

Docker Compose Structure

The project uses a modular Docker Compose structure:

  • docker-compose.yml: Main file that includes Traefik configuration and references to service-specific files
  • docker-compose/github.yml: GitHub MCP server configuration
  • docker-compose/notion.yml: Notion MCP server configuration
  • docker-compose/memory-bank.yml: Memory Bank MCP server configuration
  • docker-compose/linear.yml: Linear MCP server configuration

This modular approach allows you to:

  • Start all services: docker compose up -d (uses the default all profile set in .env)
  • Start specific services using profiles:
    • GitHub only: docker compose --profile github up -d
    • Notion only: docker compose --profile notion up -d
    • Memory Bank only: docker compose --profile memory-bank up -d
    • Linear only: docker compose --profile linear up -d
    • All services explicitly: docker compose --profile all up -d
  • Add new services easily by creating a new file in the docker-compose directory

Note: This project follows modern Docker Compose practices by omitting the version key, which is no longer required in Docker Compose V2 and above.

Note: The network configuration is defined only in the main docker-compose.yml file to avoid conflicts. All services reference this network but don’t redefine it.

Note: The default profile is set to all in the .env file using the COMPOSE_PROFILES environment variable, allowing you to run docker compose up without explicitly specifying a profile.

Accessing the Services

Once running, you can access the services using each tool’s respective path-based route

Path-based Routing

How It Works

SuperGateway

SuperGateway is used to convert between stdio and SSE transports:

  1. SuperGateway is installed in the container
  2. It runs the MCP server command using the --stdio flag
  3. It exposes HTTP endpoints for SSE connections and message sending

Traefik Configuration

Traefik is configured to:

  1. Route requests based on path prefix e.g. (/notion, /github, /dashboard)
  2. Strip the path prefix before forwarding to the appropriate service
  3. Set appropriate make sure connections don’t die
  4. Provide a dashboard for monitoring

Testing the Setup

To test the setup, you can use the MCP Inspector:

npx @modelcontextprotocol/inspector node build/index.js

Troubleshooting

  • Path routing issues: Verify the path prefixes in traefik labels, SuperGateway baseUrl option and strip middleware configuration
  • MCP server errors: Check the logs of the container:
    docker compose logs -f notion-gateway
    docker compose logs -f github-gateway
    
  • SuperGateway issues: Ensure the MCP server command is correct and the package exists in node registry- some packages advertise under different names in mcp vs node registries.

Tools

No tools

Comments

Recommend MCP Servers

View All MCP Servers