Official MCP Metaregistry

4 days ago 1

A community driven registry service for Model Context Protocol (MCP) servers.

This project is being built in the open and is currently in the early stages of development. Please see the overview discussion for the project scope and goals. If you would like to contribute, please check out the contributing guidelines.

The MCP Registry service provides a centralized repository for MCP server entries. It allows discovery and management of various MCP implementations with their associated metadata, configurations, and capabilities.

  • RESTful API for managing MCP registry entries (list, get, create, update, delete)
  • Health check endpoint for service monitoring
  • Support for various environment configurations
  • Graceful shutdown handling
  • MongoDB and in-memory database support
  • Comprehensive API documentation
  • Pagination support for listing registry entries
  • Go 1.18 or later
  • MongoDB
  • Docker (optional, but recommended for development)

The easiest way to get the registry running is to use docker compose. This will setup the MCP Registry service, import the seed data and run MongoDB in a local Docker environment.

# Build the Docker image docker build -t registry . # Run the registry and MongoDB with docker compose docker compose up

This will start the MCP Registry service and MongoDB with Docker, exposing it on port 8080.

If you prefer to run the service locally without Docker, you can build and run it directly using Go.

# Build a registry executable go build ./cmd/registry

This will create the registry binary in the current directory. You'll need to have MongoDB running locally or with Docker.

By default, the service will run on http://localhost:8080.

├── api/ # OpenApi specification ├── cmd/ # Application entry points ├── config/ # Configuration files ├── internal/ # Private application code │ ├── api/ # HTTP server and request handlers │ ├── config/ # Configuration management │ ├── model/ # Data models │ └── service/ # Business logic ├── pkg/ # Public libraries ├── scripts/ # Utility scripts └── tools/ # Command line tools └── publisher/ # Tool to publish MCP servers to the registry

The API is documented using Swagger/OpenAPI. You can access the interactive Swagger UI at:

This provides a complete reference of all endpoints with request/response schemas and allows you to test the API directly from your browser.

Returns the health status of the service:

List Registry Server Entries

Lists MCP registry server entries with pagination support.

Query parameters:

  • limit: Maximum number of entries to return (default: 30, max: 100)
  • cursor: Pagination cursor for retrieving next set of results

Response example:

{ "servers": [ { "id": "123e4567-e89b-12d3-a456-426614174000", "name": "Example MCP Server", "url": "https://example.com/mcp", "description": "An example MCP server", "created_at": "2025-05-17T17:34:22.912Z", "updated_at": "2025-05-17T17:34:22.912Z" } ], "metadata": { "next_cursor": "123e4567-e89b-12d3-a456-426614174000", "count": 30 } }

Retrieves detailed information about a specific MCP server entry.

Path parameters:

  • id: Unique identifier of the server entry

Response example:

{ "id": "01129bff-3d65-4e3d-8e82-6f2f269f818c", "name": "io.github.gongrzhe/redis-mcp-server", "description": "A Redis MCP server (pushed to https://github.com/modelcontextprotocol/servers/tree/main/src/redis) implementation for interacting with Redis databases. This server enables LLMs to interact with Redis key-value stores through a set of standardized tools.", "repository": { "url": "https://github.com/GongRzhe/REDIS-MCP-Server", "source": "github", "id": "907849235" }, "version_detail": { "version": "0.0.1-seed", "release_date": "2025-05-16T19:13:21Z", "is_latest": true }, "package_canonical": "docker", "packages": [ { "registry_name": "docker", "name": "@gongrzhe/server-redis-mcp", "version": "1.0.0", "package_arguments": [ { "description": "Docker image to run", "is_required": true, "format": "string", "value": "mcp/redis", "default": "mcp/redis", "type": "positional", "value_hint": "mcp/redis" }, { "description": "Redis server connection string", "is_required": true, "format": "string", "value": "redis://host.docker.internal:6379", "default": "redis://host.docker.internal:6379", "type": "positional", "value_hint": "host.docker.internal:6379" } ] } ] }

Publishes a new MCP server entry to the registry. Authentication is required via Bearer token in the Authorization header.

Headers:

  • Authorization: Bearer token for authentication (e.g., Bearer your_token_here)
  • Content-Type: application/json

Request body example:

{ "description": "<your description here>", "name": "io.github.<owner>/<server-name>", "package_canonical": "<package_registry", "packages": [ { "registry_name": "npm", "name": "@<owner>/<server-name>", "version": "0.2.23", "package_arguments": [ { "description": "Specify services and permissions.", "is_required": true, "format": "string", "value": "-s", "default": "-s", "type": "positional", "value_hint": "-s" } ], "environment_variables": [ { "description": "API Key to access the server", "name": "API_KEY" } ] },{ "registry_name": "docker", "name": "@<owner>/<server-name>-cli", "version": "0.123.223", "runtime_hint": "docker", "runtime_arguments": [ { "description": "Specify services and permissions.", "is_required": true, "format": "string", "value": "--mount", "default": "--mount", "type": "positional", "value_hint": "--mount" } ], "environment_variables": [ { "description": "API Key to access the server", "name": "API_KEY" } ] } ], "repository": { "url": "https://github.com//<owner>/<server-name>", "source": "github" }, "version_detail": { "version": "0.0.1-<publisher_version>" } }

Response example:

{ "message": "Server publication successful", "id": "1234567890abcdef12345678" }

Simple ping endpoint that returns environment configuration information:

{ "environment": "dev", "version": "registry-<sha>" }

The service can be configured using environment variables:

Variable Description Default
MCP_REGISTRY_APP_VERSION Application version dev
MCP_REGISTRY_COLLECTION_NAME MongoDB collection name servers_v2
MCP_REGISTRY_DATABASE_NAME MongoDB database name mcp-registry
MCP_REGISTRY_DATABASE_URL MongoDB connection string mongodb://localhost:27017
MCP_REGISTRY_GITHUB_CLIENT_ID GitHub App Client ID
MCP_REGISTRY_GITHUB_CLIENT_SECRET GitHub App Client Secret
MCP_REGISTRY_LOG_LEVEL Log level info
MCP_REGISTRY_SEED_FILE_PATH Path to import seed file data/seed.json
MCP_REGISTRY_SEED_IMPORT Import seed.json on first run true
MCP_REGISTRY_SERVER_ADDRESS Listen address for the server :8080

Run the test script to validate API endpoints:

./scripts/test_endpoints.sh

You can specify specific endpoints to test:

./scripts/test_endpoints.sh --endpoint health ./scripts/test_endpoints.sh --endpoint servers

See the LICENSE file for details.

See the CONTRIBUTING file for details.

Read Entire Article