{"id":28063737,"url":"https://github.com/modelcontextprotocol/registry","last_synced_at":"2026-03-07T01:06:48.550Z","repository":{"id":292072948,"uuid":"927890076","full_name":"modelcontextprotocol/registry","owner":"modelcontextprotocol","description":"A community driven registry service for Model Context Protocol (MCP) servers.","archived":false,"fork":false,"pushed_at":"2026-03-01T14:35:50.000Z","size":77119,"stargazers_count":6503,"open_issues_count":148,"forks_count":625,"subscribers_count":71,"default_branch":"main","last_synced_at":"2026-03-02T20:39:52.271Z","etag":null,"topics":["mcp","mcp-servers"],"latest_commit_sha":null,"homepage":"https://github.com/modelcontextprotocol/registry/tree/main/docs","language":"Go","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"other","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/modelcontextprotocol.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":"docs/contributing/add-package-registry.md","funding":null,"license":"LICENSE","code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null,"governance":null,"roadmap":null,"authors":null,"dei":null,"publiccode":null,"codemeta":null,"zenodo":null,"notice":null,"maintainers":null,"copyright":null,"agents":null,"dco":null,"cla":null}},"created_at":"2025-02-05T17:58:01.000Z","updated_at":"2026-03-02T19:44:43.000Z","dependencies_parsed_at":"2025-05-08T02:39:07.357Z","dependency_job_id":"20283b61-0902-427d-84af-7173d1d086c2","html_url":"https://github.com/modelcontextprotocol/registry","commit_stats":null,"previous_names":["modelcontextprotocol/registry"],"tags_count":21,"template":false,"template_full_name":null,"purl":"pkg:github/modelcontextprotocol/registry","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/modelcontextprotocol%2Fregistry","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/modelcontextprotocol%2Fregistry/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/modelcontextprotocol%2Fregistry/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/modelcontextprotocol%2Fregistry/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/modelcontextprotocol","download_url":"https://codeload.github.com/modelcontextprotocol/registry/tar.gz/refs/heads/main","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/modelcontextprotocol%2Fregistry/sbom","scorecard":null,"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":286080680,"owners_count":30204462,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2026-03-06T19:07:06.838Z","status":"ssl_error","status_checked_at":"2026-03-06T18:57:34.882Z","response_time":250,"last_error":"SSL_connect returned=1 errno=0 peeraddr=140.82.121.6:443 state=error: unexpected eof while reading","robots_txt_status":"success","robots_txt_updated_at":"2025-07-24T06:49:26.215Z","robots_txt_url":"https://github.com/robots.txt","online":false,"can_crawl_api":true,"host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["mcp","mcp-servers"],"created_at":"2025-05-12T12:40:51.541Z","updated_at":"2026-03-07T01:06:48.540Z","avatar_url":"https://github.com/modelcontextprotocol.png","language":"Go","readme":"# MCP Registry\n\nThe MCP registry provides MCP clients with a list of MCP servers, like an app store for MCP servers.\n\n[**📤 Publish my MCP server**](docs/modelcontextprotocol-io/quickstart.mdx) | [**⚡️ Live API docs**](https://registry.modelcontextprotocol.io/docs) | [**👀 Ecosystem vision**](docs/design/ecosystem-vision.md) | 📖 **[Full documentation](./docs)**\n\n## Development Status\n\n**2025-10-24 update**: The Registry API has entered an **API freeze (v0.1)** 🎉. For the next month or more, the API will remain stable with no breaking changes, allowing integrators to confidently implement support. This freeze applies to v0.1 while development continues on v0. We'll use this period to validate the API in real-world integrations and gather feedback to shape v1 for general availability. Thank you to everyone for your contributions and patience—your involvement has been key to getting us here!\n\n**2025-09-08 update**: The registry has launched in preview 🎉 ([announcement blog post](https://blog.modelcontextprotocol.io/posts/2025-09-08-mcp-registry-preview/)). While the system is now more stable, this is still a preview release and breaking changes or data resets may occur. A general availability (GA) release will follow later. We'd love your feedback in [GitHub discussions](https://github.com/modelcontextprotocol/registry/discussions/new?category=ideas) or in the [#registry-dev Discord](https://discord.com/channels/1358869848138059966/1369487942862504016) ([joining details here](https://modelcontextprotocol.io/community/communication)).\n\nCurrent key maintainers:\n- **Adam Jones** (Anthropic) [@domdomegg](https://github.com/domdomegg)  \n- **Tadas Antanavicius** (PulseMCP) [@tadasant](https://github.com/tadasant)\n- **Toby Padilla** (GitHub) [@toby](https://github.com/toby)\n- **Radoslav (Rado) Dimitrov** (Stacklok) [@rdimitrov](https://github.com/rdimitrov)\n\n## Contributing\n\nWe use multiple channels for collaboration - see [modelcontextprotocol.io/community/communication](https://modelcontextprotocol.io/community/communication).\n\nOften (but not always) ideas flow through this pipeline:\n\n- **[Discord](https://modelcontextprotocol.io/community/communication)** - Real-time community discussions\n- **[Discussions](https://github.com/modelcontextprotocol/registry/discussions)** - Propose and discuss product/technical requirements\n- **[Issues](https://github.com/modelcontextprotocol/registry/issues)** - Track well-scoped technical work  \n- **[Pull Requests](https://github.com/modelcontextprotocol/registry/pulls)** - Contribute work towards issues\n\n### Quick start:\n\n#### Pre-requisites\n\n- **Docker**\n- **Go 1.24.x**\n- **ko** - Container image builder for Go ([installation instructions](https://ko.build/install/))\n- **golangci-lint v2.4.0**\n\n#### Running the server\n\n```bash\n# Start full development environment\nmake dev-compose\n```\n\nThis starts the registry at [`localhost:8080`](http://localhost:8080) with PostgreSQL. The database uses ephemeral storage and is reset each time you restart the containers, ensuring a clean state for development and testing.\n\n**Note:** The registry uses [ko](https://ko.build) to build container images. The `make dev-compose` command automatically builds the registry image with ko and loads it into your local Docker daemon before starting the services.\n\nBy default, the registry seeds from the production API with a filtered subset of servers (to keep startup fast). This ensures your local environment mirrors production behavior and all seed data passes validation. For offline development you can seed from a file without validation with `MCP_REGISTRY_SEED_FROM=data/seed.json MCP_REGISTRY_ENABLE_REGISTRY_VALIDATION=false make dev-compose`.\n\nThe setup can be configured with environment variables in [docker-compose.yml](./docker-compose.yml) - see [.env.example](./.env.example) for a reference.\n\n\u003cdetails\u003e\n\u003csummary\u003eAlternative: Running a pre-built Docker image\u003c/summary\u003e\n\nPre-built Docker images are automatically published to GitHub Container Registry:\n\n```bash\n# Run latest stable release\ndocker run -p 8080:8080 ghcr.io/modelcontextprotocol/registry:latest\n\n# Run latest from main branch (continuous deployment)\ndocker run -p 8080:8080 ghcr.io/modelcontextprotocol/registry:main\n\n# Run specific release version\ndocker run -p 8080:8080 ghcr.io/modelcontextprotocol/registry:v1.0.0\n\n# Run development build from main branch\ndocker run -p 8080:8080 ghcr.io/modelcontextprotocol/registry:main-20250906-abc123d\n```\n\n**Available tags:** \n- **Releases**: `latest`, `v1.0.0`, `v1.1.0`, etc.\n- **Continuous**: `main` (latest main branch build)\n- **Development**: `main-\u003cdate\u003e-\u003csha\u003e` (specific commit builds)\n\n\u003c/details\u003e\n\n#### Publishing a server\n\nTo publish a server, we've built a simple CLI. You can use it with:\n\n```bash\n# Build the latest CLI\nmake publisher\n\n# Use it!\n./bin/mcp-publisher --help\n```\n\nSee [the publisher guide](./docs/modelcontextprotocol-io/quickstart.mdx) for more details.\n\n#### Other commands\n\n```bash\n# Run lint, unit tests and integration tests\nmake check\n```\n\nThere are also a few more helpful commands for development. Run `make help` to learn more, or look in [Makefile](./Makefile).\n\n\u003c!--\nFor Claude and other AI tools: Always prefer make targets over custom commands where possible.\n--\u003e\n\n## Architecture\n\n### Project Structure\n\n```\n├── cmd/                     # Application entry points\n│   └── publisher/           # Server publishing tool\n├── data/                    # Seed data\n├── deploy/                  # Deployment configuration (Pulumi)\n├── docs/                    # Documentation\n├── internal/                # Private application code\n│   ├── api/                 # HTTP handlers and routing\n│   ├── auth/                # Authentication (GitHub OAuth, JWT, namespace blocking)\n│   ├── config/              # Configuration management\n│   ├── database/            # Data persistence (PostgreSQL)\n│   ├── service/             # Business logic\n│   ├── telemetry/           # Metrics and monitoring\n│   └── validators/          # Input validation\n├── pkg/                     # Public packages\n│   ├── api/                 # API types and structures\n│   │   └── v0/              # Version 0 API types\n│   └── model/               # Data models for server.json\n├── scripts/                 # Development and testing scripts\n├── tests/                   # Integration tests\n└── tools/                   # CLI tools and utilities\n    └── validate-*.sh        # Schema validation tools\n```\n\n### Authentication\n\nPublishing supports multiple authentication methods:\n- **GitHub OAuth** - For publishing by logging into GitHub\n- **GitHub OIDC** - For publishing from GitHub Actions\n- **DNS verification** - For proving ownership of a domain and its subdomains\n- **HTTP verification** - For proving ownership of a domain\n\nThe registry validates namespace ownership when publishing. E.g. to publish...:\n- `io.github.domdomegg/my-cool-mcp` you must login to GitHub as `domdomegg`, or be in a GitHub Action on domdomegg's repos\n- `me.adamjones/my-cool-mcp` you must prove ownership of `adamjones.me` via DNS or HTTP challenge\n\n## Community Projects\n\nCheck out [community projects](docs/community-projects.md) to explore notable registry-related work created by the community.\n\n## More documentation\n\nSee the [documentation](./docs) for more details if your question has not been answered here!\n","funding_links":[],"categories":["Resources","Model Context Protocol (MCP) Servers","MCP Servers","📚 Projects (1974 total)","Go","Repos","Mcp Server Directories \u0026 Lists","A01_文本生成_文本对话","MCP Ecosystem","MCP \u0026 Model Context Protocol","Providers"],"sub_categories":["Official Registry","Official MCP Infrastructure","Specification-Driven Agent Development","MCP Servers","Cloud \u0026 DevOps","大语言对话模型及数据","Core \u0026 Frameworks","MCP Server Collections","MCP Registries","Codex Resources"],"project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fmodelcontextprotocol%2Fregistry","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fmodelcontextprotocol%2Fregistry","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fmodelcontextprotocol%2Fregistry/lists"}