Skip to main content
MCP 注册表目前处于预览阶段。正式可用前可能发生破坏性变更或数据重置。如果遇到问题,请在 GitHub 上反馈。
聚合器是 MCP 注册表的下游消费者,会在注册表数据之上提供额外价值。例如,服务器市场可以提供用户评分和安全扫描。 MCP 注册表提供无需认证的只读 REST API,聚合器可以用它填充自己的数据存储。聚合器应以固定但不频繁的节奏抓取数据(例如每小时一次),并将数据持久化到自己的数据存储中。MCP 注册表不保证可用时间或数据持久性

使用 MCP 注册表 REST API

MCP 注册表 REST API 的基础 URL 是 https://registry.modelcontextprotocol.io。它支持以下端点:
serverNameversion 等 URL 路径参数必须进行 URL 编码。例如,io.modelcontextprotocol/everything 必须编码为 io.modelcontextprotocol%2Feverything
聚合器最常抓取的通常是 GET /v0.1/servers 端点。

分页

GET /v0.1/servers 端点支持基于游标的分页。 例如,可以使用 limit 查询参数获取第一页:
curl "https://registry.modelcontextprotocol.io/v0.1/servers?limit=100"
Output
{
  "servers": [
    /* ... */
  ],
  "metadata": {
    "count": 100,
    "nextCursor": "com.example/my-server:1.0.0",
  },
}
之后可以将 nextCursor 的值作为 cursor 查询参数传入,以获取后续页面:
curl "https://registry.modelcontextprotocol.io/v0.1/servers?limit=100&cursor=com.example/my-server:1.0.0"

按更新时间过滤

GET /v0.1/servers 端点支持按给定时间戳过滤之后更新过的服务器。 例如,可以使用 RFC 3339 日期时间格式的 updated_since 查询参数,获取自 2025-10-23 以来更新过的服务器:
curl "https://registry.modelcontextprotocol.io/v0.1/servers?updated_since=2025-10-23T00:00:00.000Z"

服务器状态

服务器元数据通常不可变,只有 status 字段可能更新,例如更新为 "deprecated""deleted"。建议聚合器保持其副本中每个服务器的 status 为最新状态。 "deleted" 状态通常表示某个服务器违反了宽松的审核政策,可能是垃圾内容、恶意软件或非法内容。聚合器可以选择将这些服务器从索引中移除。

作为子注册表运行

子注册表是一类同时实现 MCP 注册表定义的 OpenAPI 规范的聚合器。这使 MCP host 应用等客户端能够通过标准化接口消费服务器元数据。 子注册表 OpenAPI 规范允许子注册表通过 _meta 字段注入自定义元数据。例如,子注册表可以注入用户评分、下载次数和安全扫描结果:
server.json
{
  "$schema": "https://static.modelcontextprotocol.io/schemas/2025-12-11/server.schema.json",
  "name": "io.github.username/email-integration-mcp",
  "title": "Email Integration",
  "description": "Send emails and manage email accounts",
  "version": "1.0.0",
  "packages": [
    {
      "registryType": "npm",
      "identifier": "@username/email-integration-mcp",
      "version": "1.0.0",
      "transport": {
        "type": "stdio"
      }
    }
  ],
  "_meta": {
    "com.example.subregistry/custom": {
      "user_rating": 4.5,
      "download_count": 12345,
      "security_scan": {
        "last_scanned": "2025-10-23T12:00:00Z",
        "vulnerabilities_found": 0
      }
    }
  }
}
建议将自定义元数据放在能够反映该子注册表身份的键下(例如上例中的 "com.example.subregistry/custom")。