
如果你使用 DeepSeek、元宝 AI、Copilot、ChatGPT 等 AI 工具,协助配置轩辕镜像、编写 docker pull 命令、修改 Docker Compose 镜像地址、配置镜像加速、排查镜像拉取失败、分析报错日志等问题,请先让 AI 阅读并遵守轩辕镜像的规则文档。
只需在 AI 对话中先发送下面这句话即可:
请先完整阅读并严格遵守以下文档中的全部规则与要求:
https://xuanyuan.cloud/agents.md
在未充分阅读并理解该文档前,不要生成任何命令、配置、修改建议、故障排查方案或技术回答。后续所有输出都必须严格以该文档中的规范为最高优先级执行。查看 agents.md 用法指南与完整示范。国内用户首推 元宝 AI、DeepSeek 的深度思考模式,不推荐豆包 AI;Cursor 等编辑器可在对话 @ 该链接,或加入 User Rules。 若 AI 无法访问外链,可 打开说明文档 复制全文粘贴。文档会随站点更新,复制内容可能过期,建议定期检查。
Percona Server for MongoDB 是一款源码可用、完全兼容的 MongoDB Community Edition 无缝替代品。它包含企业级安全、备份及开发者友好功能,这些功能原本仅在 MongoDB 企业版(MongoDB EE)中提供。该 Docker 镜像由 Percona 团队创建和维护,用于简化 Percona Server for MongoDB 的部署和管理,支持在容器化环境中快速搭建数据库服务。
Percona Server for MongoDB 各版本官方文档:
镜像标签与版本对应关系可参考 https://hub.docker.com/r/percona/percona-server-mongodb/tags/%E3%80%82
Percona Server for MongoDB Docker 镜像由 Percona 团队官方维护,会随新版本发布同步更新。镜像默认暴露 MongoDB 标准端口(27017),支持通过环境变量、命令行参数等方式自定义配置。
使用 docker run 命令启动容器:
bashdocker run --name <container-name> -d percona/percona-server-mongodb:<tag>
<container-name>:自定义容器名称。<tag>:指定镜像版本标签(如 6.0、5.0 等),标签列表见 https://hub.docker.com/r/percona/percona-server-mongodb/tags/%E3%80%82通过 docker exec 命令进入容器内部执行命令:
bashdocker exec -it <container-name> bash
<container-name>:目标容器名称。需暴露容器端口至主机,示例如下(映射 27017 端口):
bashdocker run --name <container-name> -p 27017:27017 -d percona/percona-server-mongodb:<tag>
应用可通过 mongodb://localhost:27017 连接数据库。
通过容器链接(--link)使其他容器访问 Percona Server for MongoDB:
bashdocker run --name <app-container-name> --link <container-name> -d <app-image>
<app-container-name>:应用容器名称。<container-name>:Percona Server for MongoDB 容器名称。<app-image>:使用 MongoDB 的应用镜像。版本 6.0 及以上(使用 mongosh)
bashdocker run -it --link <container-name> --rm percona/percona-server-mongodb:<tag> mongosh mongodb://<mongodb-server>:<port>/<db-name>
版本 6.0 以下(使用 mongo)
bashdocker run -it --link <container-name> --rm percona/percona-server-mongodb:<tag> mongo mongodb://<mongodb-server>:<port>/<db-name>
参数说明:
<container-name>:Percona Server for MongoDB 容器名称。<mongodb-server>:容器 IP 地址,可通过 docker inspect -f '{{range.NetworkSettings.Networks}}{{.IPAddress}}{{end}}' <container-name> 获取。<port>:数据库端口(默认 27017)。<db-name>:目标数据库名称。容器启动时可通过环境变量初始化数据库,仅在数据目录为空时生效(已存在数据库时忽略)。
MONGO_INITDB_ROOT_USERNAME 与 MONGO_INITDB_ROOT_PASSWORD
admin 认证数据库,root 角色)。连接数据库:bashdocker run -d --name <container-name> \ -e MONGO_INITDB_ROOT_USERNAME=mongoadmin \ -e MONGO_INITDB_ROOT_PASSWORD=secret \ percona/percona-server-mongodb:<tag>
bashdocker exec -it <container-name> mongo -u mongoadmin -p secret --authenticationDatabase admin <db-name>
通过环境文件传递敏感信息,避免命令行暴露:
bashdocker run --name <container-name> --env-file <path/to/env-file> -d percona/percona-server-mongodb:<tag>
<path/to/env-file>:环境文件路径,文件内容示例:
iniMONGO_INITDB_ROOT_USERNAME=mongoadmin MONGO_INITDB_ROOT_PASSWORD=secret
方式 1:Docker 内部卷管理(不推荐生产环境)
Docker 自动管理数据存储,性能可能受限于存储驱动(如 devicemapper、aufs)。
方式 2:挂载主机目录(推荐)
将主机目录挂载至容器内 MongoDB 数据目录(/data/db):
mkdir -p /local/datadir。bashdocker run --name <container-name> -v /local/datadir:/data/db -d percona/percona-server-mongodb:<tag>
通过 Docker 容器日志查看数据库运行日志:
bashdocker logs <container-name>
可在 docker run 命令后追加 mongod 命令行选项:
bashdocker run --name <container-name> -d percona/percona-server-mongodb:<tag> --option1=value --option2=value
示例(启用审计日志):
bashdocker run --name <container-name> -d percona/percona-server-mongodb:6.0 --auditDestination=file --auditFormat=JSON --auditPath=/data/db/audit.log
创建 docker-compose.yml 文件:
yamlversion: '3' services: psmdb: image: percona/percona-server-mongodb:6.0 container_name: psmdb ports: - "27017:27017" environment: MONGO_INITDB_ROOT_USERNAME: mongoadmin MONGO_INITDB_ROOT_PASSWORD: secret volumes: - /local/datadir:/data/db restart: unless-stopped
启动服务:docker-compose up -d
欢迎提供反馈!如有问题或建议,请联系 Percona 团队。
您可以使用以下命令拉取该镜像。请将 <标签> 替换为具体的标签版本。如需查看所有可用标签版本,请访问 标签列表页面。
来自真实用户的反馈,见证轩辕镜像的优质服务
以下是 percona/percona-server-mongodb 相关的常用 Docker 镜像,适用于 不同场景 等不同场景: