使用 rsync 进行 mongodb 副本集备份

使用 rsync 进行 mongodb 副本集备份

我已经配置了mongodb副本集(我有 3 个 db 实例 -Redhat)并且我想备份 db 文件(dbPath:/var/lib/mongo) 使用rsync,每天10或12次。

  1. 那么,我需要mongod在开始之前停止该过程吗rsync

    • 选择副本集的一台服务器并停止 mongod 进程
    • 进行备份(使用 rsync)
    • 启动 mongod 进程
  2. 或者我可以开始rsync(dbPath:/var/lib/mongo) 而不停止该mongod过程。

  3. 除了 LVM 备份之外,还推荐什么备份方法mongodump

答案1

那么,我需要mongod在开始之前停止该过程吗rsync

rsync要使用或进行文件复制备份,cp您需要通过停止mongod服务或发出以下命令来停止写入db.fsyncLock()命令在mongoshell 中或通过驱动程序。由于使用此方法备份的辅助设备将间歇性可用,因此最好将其设置为以避免驱动程序在关闭或 fsyncLock 时尝试从该成员读取数据。

我会确保您测试几个完整的备份和恢复周期。特别是,要警惕可能rsync使备份无效的选项(例如:--ignore-existing、、)。--size-only--partial

注意:如果您使用的fsyncLock()方法有db.fsyncUnLock()命令在备份完成后恢复正常操作。另一个警告:WiredTiger 存储引擎仅支持fsyncLockMongoDB 3.2 或更新版本。

我可以开始rsync(dbPath:/var/lib/mongo) 而不停止该mongod过程。

不可以。这将导致备份不一致。

除了 LVM 备份之外,还推荐什么备份方法mongodump

文档中描述了支持的备份方法:MongoDB 备份方法

有一些破坏性较小(且更连续)的备份方法,例如使用基于代理的备份服务(例如,MongoDB Cloud Manager)。

如果您希望通过复制底层数据文件进行备份,文件系统快照 (LVM/EBS/...) 通常比暂停所有写入操作破坏性更小,更值得推荐mongod。如果您想捕获一致的备份,针对正在运行的文件系统快照mongod确实有一些要求:所有数据必须位于同一卷上,必须启用日志记录,并且文件系统必须支持时间点快照。有关完整详细信息,请查看官方文档和备份教程。

相关内容