
如果你使用 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 无法访问外链,可 打开说明文档 复制全文粘贴。文档会随站点更新,复制内容可能过期,建议定期检查。
mongodb-backup-s3是一个Docker镜像,通过运行mongodump命令并结合cronjob实现MongoDB数据的定时备份,并将备份文件存储到AWS S3桶中。本镜像基于https://github.com/halvves/mongodb-backup-s3%E5%88%86%E6%94%AF%E5%BC%80%E5%8F%91%EF%BC%8C%E4%B8%BB%E8%A6%81%E5%A2%9E%E5%8A%A0%E4%BA%86%E5%AF%B9AWS S3 v4授权机制的支持,解决了以下错误:
A client error (InvalidRequest) occurred when calling the PutObject operation: The authorization mechanism you have provided is not supported. Please use AWS4-HMAC-SHA256.
该镜像可与https://github.com/deenoize/nginx-mongo-docker Docker配置良好配合使用。
bashdocker run -d \ --env AWS_ACCESS_KEY_ID=awsaccesskeyid \ --env AWS_SECRET_ACCESS_KEY=awssecretaccesskey \ --env BUCKET=mybucketname \ --env MONGODB_HOST=mongodb.host \ --env MONGODB_PORT=27017 \ --env MONGODB_USER=admin \ --env MONGODB_PASS=password \ deenoize/mongodb-backup-s3
当与MongoDB容器链接且别名为mongodb时,镜像会尝试自动加载MongoDB连接信息:
bashdocker run -d \ --env AWS_ACCESS_KEY_ID=myaccesskeyid \ --env AWS_SECRET_ACCESS_KEY=mysecretaccesskey \ --env BUCKET=mybucketname \ --env BACKUP_FOLDER=a/sub/folder/path/ \ --env INIT_BACKUP=true \ --link my_mongo_db:mongodb \ deenoize/mongodb-backup-s3
若S3桶位于非标准区域并出现永久重定向错误,需指定桶区域:
bashdocker run -d \ --env AWS_ACCESS_KEY_ID=myaccesskeyid \ --env AWS_SECRET_ACCESS_KEY=mysecretaccesskey \ --env BUCKET=mybucketname \ --env BUCKET_REGION=mybucketregion \ --env BACKUP_FOLDER=a/sub/folder/path/ \ --env INIT_BACKUP=true \ --link my_mongo_db:mongodb \ deenoize/mongodb-backup-s3
自动化备份配置
yamlmongodbbackup: image: 'deenoize/mongodb-backup-s3:latest' links: - mongodb environment: - AWS_ACCESS_KEY_ID=myaccesskeyid - AWS_SECRET_ACCESS_KEY=mysecretaccesskey - BUCKET=my-s3-bucket - BACKUP_FOLDER=prod/db/ restart: always
初始化恢复配置(适用于新实例或开发环境)
yamlmongodbbackup: image: 'deenoize/mongodb-backup-s3:latest' links: - mongodb environment: - AWS_ACCESS_KEY_ID=myaccesskeyid - AWS_SECRET_ACCESS_KEY=mysecretaccesskey - BUCKET=my-s3-bucket - BACKUP_FOLDER=prod/db/ - INIT_RESTORE=true - DISABLE_CRON=true
| 参数 | 说明 |
|---|---|
AWS_ACCESS_KEY_ID | AWS访问密钥ID(用于S3桶访问) |
AWS_SECRET_ACCESS_KEY | AWS密钥(用于S3桶访问) |
BUCKET | S3桶名称 |
BUCKET_REGION | S3桶区域(如us-east-2),可选,解决"PermanentRedirect"错误时需指定 |
BACKUP_FOLDER | 备份文件存储路径(如myapp/db_backups/),默认存储在桶根目录 |
MONGODB_HOST | MongoDB数据库主机/IP |
MONGODB_PORT | MongoDB数据库端口号 |
MONGODB_USER | MongoDB数据库用户名,若密码非空而用户名为空,默认使用admin |
MONGODB_PASS | MongoDB数据库密码 |
MONGODB_DB | 需备份的数据库名称,未指定时备份所有数据库 |
EXTRA_OPTS | 传递给mongodump命令的额外参数 |
CRON_TIME | cron任务执行间隔,默认0 3 * * *(每天凌晨3点) |
TZ | 时区,默认US/Eastern |
CRON_TZ | cron任务时区,默认US/Eastern |
INIT_BACKUP | 若设置,容器启动时立即创建备份 |
INIT_RESTORE | 若设置,容器启动时从最新备份恢复数据 |
DISABLE_CRON | 若设置,不启用自动备份,适用于仅需初始化恢复的场景 |
bashdocker exec mongodb-backup-s3 /listbackups.sh
bashdocker exec mongodb-backup-s3 /restore.sh 20170406T155812
bashdocker exec mongodb-backup-s3 /restore.sh
本镜像基于以下项目开发:
您可以使用以下命令拉取该镜像。请将 <标签> 替换为具体的标签版本。如需查看所有可用标签版本,请访问 标签列表页面。





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