- MongoDB官方文档中文版
- MongoDB中文手册说明
- MongoDB简介
- 安装 MongoDB
- The mongo Shell
- MongoDB CRUD 操作
- 聚合
- 数据模型
- 事务
- 索引
- 安全
- 安全检查列表
- 启用访问控制
- 身份验证
- 基于角色的访问控制
- TLS / SSL(传输加密)
- 静态加密
- 客户端字段级加密
- 审计
- 网络和配置强化
- 实现字段级别修订
- 安全参考
- 附录
- 变更流
- 复制
- 分片
- 分片键
- 哈希分片
- 范围分片
- 区
- 管理分片区
- 按位置细分数据
- 用于更改SLA或SLO的分层硬件
- 按应用或客户细分数据
- 仅插入工作负载的分布式本地写入
- 管理分片区
- 使用块进行数据分区
- 在分片集群中拆分数据块
- 管理
- 存储
- 存储引擎
- 日志记录
- 管理日志记录
- GridFS
- FAQ:MongoDB 存储
- 存储引擎
- 参考
- 运算符
- 查询与映射运算符
- 更新运算符
- 聚合管道阶段
- 聚合管道操作符
- $abs (aggregation)
- $acos (aggregation)
- $acosh (aggregation)
- $add (aggregation)
- $addToSet (aggregation)
- $allElementsTrue (aggregation)
- $and (aggregation)
- $anyElementTrue (aggregation)
- $arrayElemAt (aggregation)
- $arrayToObject (aggregation)
- $asin (aggregation)
- $asinh (aggregation)
- $atan (aggregation)
- $atan2 (aggregation)
- $atanh (aggregation)
- $avg (aggregation)
- $ceil (aggregation)
- $cmp (aggregation)
- $concat (aggregation)
- $concatArrays (aggregation)
- $cond (aggregation)
- $convert (aggregation)
- $cos (aggregation)
- $dateFromParts (aggregation)
- $dateToParts (aggregation)
- $dateFromString (aggregation)
- $literal (aggregation)
- 查询修饰符
- 数据库命令
- 聚合命令
- 地理空间命令
- 查询和写操作命令
- 查询计划缓存命令
- 认证命令
- 用户管理命令
- 角色管理命令
- 复制命令
- 分片命令
- 会话命令
- 管理命令
- 诊断命令
- 免费监控命令
- 系统事件审计命令
- mongo Shell 方法
- 集合方法
- db.collection.aggregate()
- db.collection.bulkWrite()
- db.collection.copyTo()
- db.collection.count()
- db.collection.countDocuments()
- db.collection.estimatedDocumentCount()
- db.collection.createIndex()
- db.collection.createIndexes()
- db.collection.dataSize()
- db.collection.deleteOne()
- db.collection.deleteMany()
- db.collection.distinct()
- db.collection.drop()
- db.collection.dropIndex()
- db.collection.dropIndexes()
- db.collection.ensureIndex()
- db.collection.explain()
- db.collection.find()
- db.collection.findAndModify()
- db.collection.findOne()
- db.collection.findOneAndDelete()
- db.collection.findOneAndReplace()
- db.collection.findOneAndUpdate()
- db.collection.getIndexes()
- db.collection.getShardDistribution()
- db.collection.getShardVersion()
- db.collection.insert()
- db.collection.insertOne()
- db.collection.insertMany()
- db.collection.isCapped()
- db.collection.latencyStats()
- db.collection.mapReduce()
- db.collection.reIndex()
- db.collection.remove()
- db.collection.renameCollection()
- db.collection.replaceOne()
- db.collection.save()
- db.collection.stats()
- db.collection.storageSize()
- db.collection.totalIndexSize()
- db.collection.totalSize()
- db.collection.update()
- db.collection.updateOne()
- db.collection.updateMany()
- db.collection.watch()
- db.collection.validate()
- 词汇表
- 默认的MongoDB端口
- 默认的MongoDB读/写关注
- 服务器会话
- MongoDB驱动
- FAQ
- 联系我们
- 更多资料
- [快学Mongo]
- [Mongo问题讨论区]
- [Mongo 驱动使用手册]
- 本书使用 GitBook 发布
MongoDB备份方法
MogoDB 备份方法
在本页
当在生产环境中部署 MongoDB 时,应该制定一种策略,以备在发生数据丢失事件时捕获和还原备份。
使用 Atlas 进行备份
MongoDB 官方云服务 MongoDB Atlas 提供2种完全托管的备份方法
连续备份,它对群集中的数据进行增量备份,从而确保备份通常仅比操作系统落后几秒钟。利用 Atlas 连续备份,您可以从存储的快照或最近24小时内的选定时间点还原。您还可以查询连续备份快照。
云提供商快照,使用集群的云服务提供商的原生快照功能提供的本地化的备份存储。
使用 MongoDB Cloud Manage 或者 Ops Manager
MongoDB Cloud Manager 是针对 MongoDB 的托管备份,监控和自动化服务。MongoDB Cloud Manager 支持用户在图形化界面操作备份和还原 MongoDB 副本集和分片集群.
MongoDB Cloud Manager
MongoDB Cloud Manager 支持 MongoDB 部署的备份和恢复
通过从 MongoDB 部署中读取操作日志数据,MongoDB Cloud Manager 持续备份 MongoDB 副本集和分片群集。MongoDB Cloud Manager 会按设置的时间间隔创建数据快照,还可以提供 MongoDB 副本集和分片群集的时间点恢复。
提示
使用其他 MongoDB 备份方法很难实现分片群集快照。
要开始使用 MongoDB Cloud Manager 备份,请注册 MongoDB Cloud Manager。有关 MongoDB Cloud Manager 的文档,请参阅 MongoDB Cloud Manager 的文档。
Ops Manager
借助 Ops Manager,MongoDB 用户可以在自己的基础架构上安装和运行驱动 MongoDB Cloud Manager 的相同核心软件。Ops Manager 是一种本地解决方案,具有与 MongoDB Cloud Manager 相似的功能,可与订阅的企业版高级功能一起使用。
For more information about Ops Manager, see the MongoDB Enterprise Advanced page and the Ops Manager Manual.
有关更多 Ops Manager,请看MongoDB 企业版高级高级功能 和 Ops Manager 操作手册.
通过复制基础数据文件进行备份
使用 AES256-GCM 的加密存储引擎的注意事项
对于使用 AES256-GCM
加密模式的加密存储引擎,AES256-GCM 要求每个进程都使用唯一的计数器块值和密钥。
对于配置了 AES256-GCM
密码加密存储引擎:
- 从热备份还原
从 4.2 开始,如果您通过“热”备份(即 mongod
正在运行)获取的文件进行还原,MongoDB 可以在启动时检测“脏”密钥并自动翻转数据库密钥以避免IV(初始化向量)重用。
- 从冷备份还原
但是, 如果您通过“冷”备份获取的文件恢复(即 mongod
没有在运行),则MongoDB无法在启动时检测到“脏”密钥,并且IV的重用会使机密性和完整性保证无效。
从4.2开始, 为了避免从冷的文件系统快照还原后重新使用密钥,MongoDB 添加了一个新的命令行选项 --eseDatabaseKeyRollover
. 使用--eseDatabaseKeyRollover
选项启动, mongod
实例将回滚使用 AES256-GCM
密码配置的数据库密钥,然后退出。
提示
- In general, if using filesystem based backups for MongoDB Enterprise 4.2+, use the “hot” backup feature, if possible.
- 通常,如果对 MongoDB Enterprise 4.2+ 使用基于文件系统的备份,情尽可能使用“热”备份功能。
- For MongoDB Enterprise versions 4.0 and earlier, if you use
AES256-GCM
encryption mode, do not make copies of your data files or restore from filesystem snapshots (“hot” or “cold”). - 对于 MongoDB Enterprise 4.0 及更早版本,如果您使用
AES256-GCM
加密模式,请不要复制数据文件或从文件系统快照(“热”或“冷”)还原。
使用文件系统快照备份
您可以通过复制MongoDB的基础数据文件来创建MongoDB部署的备份。
如果 MongoDB 存储数据文件的卷支持时间点快照,则可以使用这些快照在确切的时间创建 MongoDB 系统的备份。文件系统快照是操作系统卷管理器功能,并非特定于 MongoDB。借助文件系统快照,操作系统可以获取卷的快照以用作数据备份的基准。快照的机制取决于基础存储系统。例如,在 Linux 上,逻辑卷管理器(LVM)可以创建快照。同样,Amazon 的 EC2 EBS 存储系统支持快照。
要获取正在运行的 mongod 进程的正确快照,您必须启用日记功能,并且日记必须与其他MongoDB 数据文件位于同一逻辑卷上。如果未启用日记功能,则无法保证快照将保持一致或有效。
要获得分片群集的一致快照,必须禁用平衡器并在大约同一时间从每个分片以及配置服务器捕获快照。
欲了解更多信息,请参阅使用文件系统快照备份和恢复 和 使用文件系统快照备份分片集群使用 LVM 创建快照的完整说明。
使用 cp
或者 rsync
备份
如果存储系统不支持快照,可以直接使用 cp,rsync 或类似的工具拷贝文件。由于复制多个文件不是原子操作,因此必须mongod
在复制文件之前停止对的所有写操作。否则,您将以无效状态复制文件。
通过复制基础数据生成的备份不支持副本集的时间点恢复,并且对于较大的分片群集很难管理。此外,这些备份更大,因为它们包括索引以及重复的基础存储填充和碎片。mongodump 相反,创建的备份较小。
使用 mongodump
备份
mongodump
从 MongoDB 数据库读取数据,并创建高保真 BSON 文件,该 mongorestore
工具可用于填充 MongoDB 数据库。 mongodump
和 mongorestore
是用于备份和还原小型 MongoDB 部署的简单高效的工具,但是对于捕获大型系统的备份而言并不是理想的选择。
mongodump
和 mongorestore
针对正在运行的 mongod
进程进行操作,并且可以直接操作基础数据文件。默认情况下,mongodump 不捕获本地数据库的内容。
mongodump
仅捕获数据库中的文档。生成的备份是节省空间的,但是mongorestore
或 mongod
恢复数据后,必须重建索引。
当连接一个 MongoDB 实例时,mongodump
可能会对mongod
的性能产生不利影响。如果您的数据大于系统内存,则查询会将工作集推出内存,从而导致页面错误。
应用程序可以在 mongodump
捕获输出的同时继续修改数据,对于副本集,当进行mongodump
操作时,mongodump
提供 --oplog
选项来包括它输出的oplog 实体。这允许响应的mongorestore
恢复捕获的 oplog。要恢复创建时带了--oplog
选项的备份,进行mongorestore
操作是需要有 --oplogReplay
选项。
但是对于副本集,请考虑使用 MongoDB Cloud Manager 或 Ops Manager。
注意
mongodump
和 mongorestore
不能作为正在进行分片事务的4.2+版本分片群集的备份策略的一部分,因为使用创建的备份不会保持跨分片事务的原子性保证。
对于具有正在进行的分片事务的 4.2+ 版本分片集群,请使用以下一个协调的备份和还原过程,这些过程确实维护了跨分片事务的原子性保证:
有关更多信息请参阅Back Up and Restore with MongoDB Tools 和 Back Up a Sharded Cluster with Database Dumps
译者:谢伟成
Copyright © 上海锦木信息技术有限公司 all right reserved,由 MongoDB汉化小组 提供技术支持文件修订时间: 2020-10-11 20:53:05