我已经配置了mongodb副本集(我有 3 个 db 实例 -Redhat),我想每天使用 10 或 12 次备份 db 文件( dbPath: /var/lib/mongo) 。rsync
那么,我需要
mongod
在开始之前停止该过程rsync
吗?- 选择副本集的服务器之一并停止mongod进程
- 进行备份(使用 rsync)
- 启动mongod进程
否则,我可以在不停止进程的情况下启动
rsync
(dbPath: /var/lib/mongo )。mongod
除了 LVM 备份和推荐的备份方法是什么
mongodump
?
要进行文件复制备份,
rsync
或者您需要通过停止服务或在shell 中或通过驱动程序发出命令cp
来停止写入。由于您要从中备份的辅助设备将通过这种方法间歇性地可用,因此最好将其隐藏以避免驱动程序在该成员关闭或 fsyncLock'd 时尝试读取该成员。mongod
db.fsyncLock()
mongo
我会确保您测试几个完整的备份和恢复周期。特别要
rsync
注意可能使备份无效的选项(例如:--ignore-existing
、、、--size-only
)--partial
。注意:如果您使用该
fsyncLock()
方法,则db.fsyncUnLock()
备份完成后有一个命令可以恢复正常操作。另一个警告:WiredTiger 存储引擎仅支持fsyncLock
MongoDB 3.2 或更高版本。不会。这将导致备份不一致。
支持的备份方法在文档中描述:MongoDB Backup Methods。
有更少破坏性(和更连续)的备份方法,例如使用基于代理的备份服务(例如,MongoDB Cloud Manager)。
如果您想通过复制底层数据文件进行备份,文件系统快照 (LVM/EBS/...) 通常比暂停所有对
mongod
. 如果要捕获一致的备份,针对正在运行的文件系统快照mongod
确实有一些要求:所有数据必须位于同一卷上,必须启用日记功能,并且文件系统必须支持时间点快照。有关完整详细信息,请查看官方文档和备份教程。