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