专属域名
文档搜索
轩辕助手
Run助手
邀请有礼
返回顶部
快速返回页面顶部
收起
收起工具栏

mongodb/mongodb-mcp-server Docker 镜像 - 轩辕镜像

mongodb-mcp-server
mongodb/mongodb-mcp-server
官方MongoDB MCP服务器镜像,用于部署和运行MongoDB MCP服务,提供官方支持的可靠运行环境。
1 收藏0 次下载activemongodb镜像
🚀专业版镜像服务,面向生产环境设计
中文简介版本下载
🚀专业版镜像服务,面向生产环境设计

MongoDB MCP Server

MongoDB官方MCP服务器,一个用于与MongoDB数据库和MongoDB Atlas交互的模型上下文协议(Model Context Protocol)服务器。

镜像概述和主要用途

MongoDB MCP Server是实现模型上下文协议(MCP)的服务器,提供与MongoDB数据库和MongoDB Atlas云服务的交互能力。该服务器允许MCP客户端通过标准化接口访问MongoDB工具和服务,实现数据库管理、集群操作和数据查询等功能。

核心功能和特性

  • 提供MongoDB Atlas云服务管理工具,支持组织、项目和集群的创建与管理
  • 提供MongoDB数据库操作工具,支持数据查询、插入、更新和删除等操作
  • 灵活的配置选项,支持直接数据库连接或Atlas API认证
  • 可定制的工具访问控制,支持禁用特定工具或操作类型
  • 只读模式支持,限制仅允许读取和元数据操作
  • 完整的日志记录功能,便于问题诊断和审计

使用场景和适用范围

MongoDB MCP Server适用于需要通过MCP协议与MongoDB交互的各类客户端应用,包括但不限于:

  • 开发环境中的数据库管理和操作
  • 通过AI助手或IDE插件访问MongoDB数据库
  • 自动化脚本和工作流中的数据库操作
  • MongoDB Atlas云服务的远程管理
  • 需要限制数据库操作权限的共享环境

支持的MCP客户端包括:Windsurf、VSCode、Claude Desktop和Cursor等。

前提条件

  • Node.js (v20或更高版本)
shell
node -v
  • MongoDB连接字符串或Atlas API凭据,服务器未配置将无法启动。
    • 使用Atlas工具需要服务账户Atlas API凭据。可在MongoDB Atlas中创建服务账户并使用其凭据进行认证。详见"Atlas API访问"部分。
    • 若已有MongoDB连接字符串,可直接用于连接MongoDB实例。

详细使用方法和配置说明

快速开始

大多数MCP客户端需要创建或修改配置文件以添加MCP服务器。

注意:不同客户端的配置文件语法可能不同。请参考以下链接获取最新语法说明:

  • Windsurf: [***]
  • VSCode: [***]
  • Claude Desktop: [***]
  • Cursor: [***]

您可以提供MongoDB连接字符串或Atlas API凭据:

选项A: 无配置
shell
docker run --rm -i \
  mongodb/mongodb-mcp-server:latest
选项B: 使用MongoDB连接字符串
shell
docker run --rm -i \
  -e MDB_MCP_CONNECTION_STRING="mongodb+srv://username:***/myDatabase" \
  mongodb/mongodb-mcp-server:latest
选项C: 使用Atlas API凭据
shell
docker run --rm -i \
  -e MDB_MCP_API_CLIENT_ID="your-atlas-service-accounts-client-id" \
  -e MDB_MCP_API_CLIENT_SECRET="your-atlas-service-accounts-client-secret" \
  mongodb/mongodb-mcp-server:latest
MCP配置文件

无选项配置:

json
{
  "mcpServers": {
    "MongoDB": {
      "command": "docker",
      "args": ["run", "--rm", "-i", "mongodb/mongodb-mcp-server:latest"]
    }
  }
}

使用连接字符串:

json
{
  "mcpServers": {
    "MongoDB": {
      "command": "docker",
      "args": [
        "run",
        "--rm",
        "-i",
        "-e",
        "MDB_MCP_CONNECTION_STRING=mongodb+srv://username:***/myDatabase",
        "mongodb/mongodb-mcp-server:latest"
      ]
    }
  }
}

使用Atlas API凭据:

json
{
  "mcpServers": {
    "MongoDB": {
      "command": "docker",
      "args": [
        "run",
        "--rm",
        "-i",
        "-e",
        "MDB_MCP_API_CLIENT_ID=your-atlas-service-accounts-client-id",
        "-e",
        "MDB_MCP_API_CLIENT_SECRET=your-atlas-service-accounts-client-secret",
        "mongodb/mongodb-mcp-server:latest"
      ]
    }
  }
}
支持的工具
工具列表

MongoDB Atlas工具

  • atlas-list-orgs - 列出MongoDB Atlas组织
  • atlas-list-projects - 列出MongoDB Atlas项目
  • atlas-create-project - 创建新的MongoDB Atlas项目
  • atlas-list-clusters - 列出MongoDB Atlas集群
  • atlas-inspect-cluster - 检查特定的MongoDB Atlas集群
  • atlas-create-free-cluster - 创建免费的MongoDB Atlas集群
  • atlas-connect-cluster - 连接到MongoDB Atlas集群
  • atlas-inspect-access-list - 检查有权访问MongoDB Atlas集群的IP/CIDR范围
  • atlas-create-access-list - 配置MongoDB Atlas集群的IP/CIDR访问列表
  • atlas-list-db-users - 列出MongoDB Atlas数据库用户
  • atlas-create-db-user - 创建MongoDB Atlas数据库用户

注意:Atlas工具仅在配置部分设置凭据后可用。

MongoDB数据库工具

  • connect - 连接到MongoDB实例
  • find - 对MongoDB集合运行查询
  • aggregate - 对MongoDB集合运行聚合操作
  • count - 获取MongoDB集合中的文档数量
  • insert-one - 向MongoDB集合插入单个文档
  • insert-many - 向MongoDB集合插入多个文档
  • create-index - 为MongoDB集合创建索引
  • update-one - 更新MongoDB集合中的单个文档
  • update-many - 更新MongoDB集合中的多个文档
  • rename-collection - 重命名MongoDB集合
  • delete-one - 从MongoDB集合中删除单个文档
  • delete-many - 从MongoDB集合中删除多个文档
  • drop-collection - 从MongoDB数据库中删除集合
  • drop-database - 删除MongoDB数据库
  • list-databases - 列出MongoDB连接的所有数据库
  • list-collections - 列出给定数据库的所有集合
  • collection-indexes - 描述集合的索引
  • collection-schema - 描述集合的模式
  • collection-storage-size - 获取集合的大小(MB)
  • db-stats - 返回MongoDB数据库的统计信息
配置

MongoDB MCP Server可通过多种方法配置,优先级从高到低如下:

  1. 命令行参数
  2. 环境变量
配置选项
选项描述
apiClientId用于认证的Atlas API客户端ID
apiClientSecret用于认证的Atlas API客户端密钥
connectionStringMongoDB连接字符串,用于直接数据库连接(可选,用户可在每次工具调用时提供)
logPath存储日志的文件夹
disabledTools要禁用的工具名称、操作类型和/或工具类别的数组
readOnly设置为true时,仅允许读取和元数据操作类型,禁用创建/更新/删除操作
telemetry设置为disabled时,禁用遥测数据收集

日志路径

默认日志位置如下:

  • Windows: %LOCALAPPDATA%\mongodb\mongodb-mcp\.app-logs
  • macOS/Linux: ~/.mongodb/mongodb-mcp/.app-logs

禁用工具

可以使用disabledTools选项禁用特定工具或工具类别。此选项接受字符串数组,其中每个字符串可以是工具名称、操作类型或类别。

数组的构造方式取决于所使用的配置方法:

  • 对于环境变量配置,使用逗号分隔的字符串:export MDB_MCP_DISABLED_TOOLS="create,update,delete,atlas,collectionSchema"。
  • 对于命令行参数配置,使用空格分隔的字符串:--disabledTools create update delete atlas collectionSchema。

工具类别:

  • atlas - MongoDB Atlas工具,如列出集群、创建集群等。
  • mongodb - MongoDB数据库工具,如find、aggregate等。

操作类型:

  • create - 创建资源的工具,如创建集群、插入文档等。
  • update - 更新资源的工具,如更新文档、重命名集合等。
  • delete - 删除资源的工具,如删除文档、删除集合等。
  • read - 读取资源的工具,如查询、聚合、列出集群等。
  • metadata - 读取元数据的工具,如列出数据库、列出集合、集合模式等。

只读模式

readOnly配置选项允许将MCP服务器限制为仅使用具有"read"和"metadata"操作类型的工具。启用后,所有具有"create"、"update"或"delete"操作类型的工具将不会在服务器上注册。

这在希望提供MongoDB数据访问进行分析但不允许修改数据或基础设施的场景中非常有用。

可以通过以下方式启用只读模式:

  • 环境变量: export MDB_MCP_READ_ONLY=true
  • 命令行参数: --readOnly

当只读模式激活时,服务器日志中将显示一条消息,指示由于此限制而阻止注册的工具。

遥测

telemetry配置选项允许禁用遥测数据收集。启用时,MCP服务器将收集使用数据并发送给MongoDB。

可以通过以下方式禁用遥测:

  • 环境变量: export MDB_MCP_TELEMETRY=disabled
  • 命令行参数: --telemetry disabled
  • DO_NOT_TRACK环境变量: export DO_NOT_TRACK=1
Atlas API访问

要使用Atlas API工具,需要在MongoDB Atlas中创建服务账户:

  1. 创建服务账户:

    • 登录MongoDB Atlas: cloud.mongodb.com
    • 导航至"访问管理器">"组织访问"
    • 点击"添加新">"应用">"服务账户"
    • 输入服务账户的名称、描述和过期时间(例如:"MCP, MCP Server Access, 7 days")
    • 选择适当的权限(如需完全访问,请使用组织所有者)
    • 点击"创建"

要了解有关服务账户的更多信息,请查看MongoDB Atlas文档。

  1. 保存客户端凭据:

    • 创建后,将显示客户端ID和客户端密钥
    • 重要提示: 立即复制并保存客户端密钥,因为它不会再次显示
  2. 添加访问列表条目:

    • 将您的IP地址添加到API访问列表
  3. 配置MCP服务器:

    • 使用以下配置方法之一设置apiClientId和apiClientSecret
配置方法

环境变量

设置以MDB_MCP_为前缀的环境变量,后跟大写的选项名称(使用下划线分隔):

shell
# 设置Atlas API凭据(通过服务账户)
export MDB_MCP_API_CLIENT_ID="your-atlas-service-accounts-client-id"
export MDB_MCP_API_CLIENT_SECRET="your-atlas-service-accounts-client-secret"

# 设置自定义MongoDB连接字符串
export MDB_MCP_CONNECTION_STRING="mongodb+srv://username:***/myDatabase"

export MDB_MCP_LOG_PATH="/path/to/logs"

Docker部署示例:

shell
docker run --rm -i \
  -e MDB_MCP_API_CLIENT_ID="your-atlas-service-accounts-client-id" \
  -e MDB_MCP_API_CLIENT_SECRET="your-atlas-service-accounts-client-secret" \
  -e MDB_MCP_CONNECTION_STRING="mongodb+srv://username:***/myDatabase" \
  mongodb/mongodb-mcp-server:latest

MCP配置文件示例

使用环境变量的连接字符串配置:

json
{
  "mcpServers": {
    "MongoDB": {
      "command": "docker",
      "args": ["run", "-i", "--rm", "mongodb/mongodb-mcp-server"],
      "env": {
        "MDB_MCP_CONNECTION_STRING": "mongodb+srv://username:***/myDatabase"
      }
    }
  }
}

使用Atlas API凭据的配置:

json
{
  "mcpServers": {
    "MongoDB": {
      "command": "docker",
      "args": ["run", "-i", "--rm", "mongodb/mongodb-mcp-server"],
      "env": {
        "MDB_MCP_API_CLIENT_ID": "your-atlas-service-accounts-client-id",
        "MDB_MCP_API_CLIENT_SECRET": "your-atlas-service-accounts-client-secret"
      }
    }
  }
}

命令行参数

启动服务器时将配置选项作为命令行参数传递:

shell
docker run -i --rm mongodb/mongodb-mcp-server \
  --apiClientId="your-atlas-service-accounts-client-id" \
  --apiClientSecret="your-atlas-service-accounts-client-secret" \
  --connectionString="mongodb+srv://username:***/myDatabase" \
  --logPath=/path/to/logs

使用命令行参数的MCP配置文件示例:

json
{
  "mcpServers": {
    "MongoDB": {
      "command": "docker",
      "args": [
        "run",
        "-i",
        "--rm",
        "mongodb/mongodb-mcp-server",
        "--connectionString",
        "mongodb+srv://username:***/myDatabase"
      ]
    }
  }
}
Docker Compose配置示例
yaml
version: '3'
services:
  mongodb-mcp-server:
    image: mongodb/mongodb-mcp-server:latest
    environment:
      - MDB_MCP_API_CLIENT_ID=your-atlas-service-accounts-client-id
      - MDB_MCP_API_CLIENT_SECRET=your-atlas-service-accounts-client-secret
      # 或者使用直接连接字符串
      # - MDB_MCP_CONNECTION_STRING=mongodb+srv://username:***/myDatabase
      - MDB_MCP_LOG_PATH=/logs
      - MDB_MCP_READ_ONLY=false
      - MDB_MCP_TELEMETRY=enabled
    volumes:
      - ./logs:/logs
    stdin_open: true
    tty: true

贡献

有兴趣贡献吗?太好了!请查看我们的贡献指南,了解代码贡献、标准、添加新工具和故障排除信息的指南。

查看更多 mongodb-mcp-server 相关镜像 →
mongodb/mongodb-community-server logo
mongodb/mongodb-community-server
by MongoDB
认证
官方MongoDB社区服务器是由MongoDB公司推出的免费开源文档数据库服务,专为开发者与技术社区打造,支持以JSON格式存储灵活的非结构化及半结构化数据,具备高可扩展性、易部署性和丰富的查询功能,广泛应用于Web开发、大数据分析、移动应用后端等场景,为用户提供高效的数据管理解决方案并促进社区协作与技术交流。
17410M+ pulls
上次更新:4 天前
mongodb/mongodb-enterprise-server logo
mongodb/mongodb-enterprise-server
by MongoDB
认证
MongoDB官方企业高级服务器是面向企业级应用的高性能、可扩展文档数据库服务器,支持复杂查询、分布式部署与实时数据分析,提供企业级安全特性(如身份验证、数据加密)、完善的数据备份与恢复机制及专业监控工具,助力企业构建稳定高效的现代应用架构,满足大规模数据存储、处理与业务创新需求。
141M+ pulls
上次更新:4 天前
mongodb/mongodb-atlas-local logo
mongodb/mongodb-atlas-local
by MongoDB
认证
通过Docker创建、管理和自动化MongoDB Atlas Local资源
101M+ pulls
上次更新:6 天前
mongodb/mongodb-atlas-kubernetes-operator logo
mongodb/mongodb-atlas-kubernetes-operator
by MongoDB
认证
MongoDB Atlas Kubernetes Operator - 基于Kubernetes原生管理MongoDB Atlas基础设施
51M+ pulls
上次更新:4 天前
mongodb/mongodb-atlas-search logo
mongodb/mongodb-atlas-search
by MongoDB
认证
Atlas Search提供无缝、可扩展的体验,用于构建基于相关性的应用功能。
31M+ pulls
上次更新:30 天前
mongodb/mongodb-community-search logo
mongodb/mongodb-community-search
by MongoDB
认证
MongoDB Community Search Docker镜像由MongoDB官方维护,提供MongoDB社区版的搜索功能支持,适用于部署具备搜索能力的MongoDB社区版实例,可通过官方文档、Reddit社区及技术支持获取帮助。
10K+ pulls
上次更新:2 个月前

轩辕镜像配置手册

探索更多轩辕镜像的使用方法,找到最适合您系统的配置方式

登录仓库拉取

通过 Docker 登录认证访问私有仓库

Linux

在 Linux 系统配置镜像服务

Windows/Mac

在 Docker Desktop 配置镜像

Docker Compose

Docker Compose 项目配置

K8s Containerd

Kubernetes 集群配置 Containerd

K3s

K3s 轻量级 Kubernetes 镜像加速

宝塔面板

在宝塔面板一键配置镜像

群晖

Synology 群晖 NAS 配置

飞牛

飞牛 fnOS 系统配置镜像

极空间

极空间 NAS 系统配置服务

爱快路由

爱快 iKuai 路由系统配置

绿联

绿联 NAS 系统配置镜像

威联通

QNAP 威联通 NAS 配置

Podman

Podman 容器引擎配置

Singularity/Apptainer

HPC 科学计算容器配置

其他仓库配置

ghcr、Quay、nvcr 等镜像仓库

专属域名拉取

无需登录使用专属域名

需要其他帮助?请查看我们的 常见问题Docker 镜像访问常见问题解答 或 提交工单

镜像拉取常见问题

轩辕镜像免费版与专业版有什么区别?

免费版仅支持 Docker Hub 访问,不承诺可用性和速度;专业版支持更多镜像源,保证可用性和稳定速度,提供优先客服响应。

轩辕镜像支持哪些镜像仓库?

专业版支持 docker.io、gcr.io、ghcr.io、registry.k8s.io、nvcr.io、quay.io、mcr.microsoft.com、docker.elastic.co 等;免费版仅支持 docker.io。

流量耗尽错误提示

当返回 402 Payment Required 错误时,表示流量已耗尽,需要充值流量包以恢复服务。

410 错误问题

通常由 Docker 版本过低导致,需要升级到 20.x 或更高版本以支持 V2 协议。

manifest unknown 错误

先检查 Docker 版本,版本过低则升级;版本正常则验证镜像信息是否正确。

镜像拉取成功后,如何去掉轩辕镜像域名前缀?

使用 docker tag 命令为镜像打上新标签,去掉域名前缀,使镜像名称更简洁。

查看全部问题→

用户好评

来自真实用户的反馈,见证轩辕镜像的优质服务

oldzhang的头像

oldzhang

运维工程师

Linux服务器

5

"Docker访问体验非常流畅,大镜像也能快速完成下载。"

轩辕镜像
镜像详情
...
mongodb/mongodb-mcp-server
官方博客Docker 镜像使用技巧与技术博客
热门镜像查看热门 Docker 镜像推荐
一键安装一键安装 Docker 并配置镜像源
提交工单
免费获取在线技术支持请 提交工单,官方QQ群:13763429 。
轩辕镜像面向开发者与科研用户,提供开源镜像的搜索和访问支持。所有镜像均来源于原始仓库,本站不存储、不修改、不传播任何镜像内容。
免费获取在线技术支持请提交工单,官方QQ群: 。
轩辕镜像面向开发者与科研用户,提供开源镜像的搜索和访问支持。所有镜像均来源于原始仓库,本站不存储、不修改、不传播任何镜像内容。
官方邮箱:点击复制邮箱
©2024-2026 源码跳动
官方邮箱:点击复制邮箱Copyright © 2024-2026 杭州源码跳动科技有限公司. All rights reserved.
轩辕镜像 官方专业版 Logo
轩辕镜像轩辕镜像官方专业版
首页个人中心搜索镜像
交易
充值流量我的订单
工具
提交工单镜像收录一键安装
Npm 源Pip 源Homebrew 源
帮助
常见问题
其他
关于我们网站地图

官方QQ群: 13763429