MongoDB(70)如何使用副本集进行备份?

18 阅读3分钟

使用副本集进行备份是一个常见的MongoDB备份策略,因为副本集提供了数据冗余和高可用性。通过从副本集中读取数据,可以在不影响主节点的情况下进行备份。以下是详细的步骤和示例代码,展示如何使用 MongoDB 副本集进行备份。

方法一:从次要节点进行备份

为了减少对主节点(primary)的影响,可以从副本集的次要节点(secondary)执行备份。

步骤1:确保副本集配置正确

首先,确保MongoDB已配置为副本集。查看副本集配置:

rs.status()

确保副本集中的节点状态正常。

步骤2:连接到次要节点

使用 mongodump 工具连接到次要节点并进行备份。假设次要节点的地址是 secondary_host:27017

连接到次要节点
mongodump --host secondary_host --port 27017 --out /path/to/backup

如果副本集启用了身份验证,还需要提供用户名和密码:

mongodump --host secondary_host --port 27017 --username your_username --password your_password --authenticationDatabase admin --out /path/to/backup

方法二:使用文件系统快照进行备份

使用文件系统快照(例如LVM快照或ZFS快照)可以对MongoDB数据目录进行快速一致性的备份。

步骤1:锁定次要节点

在进行文件系统快照之前,需要锁定次要节点以确保数据一致性。

连接到次要节点并锁定
mongo --host secondary_host --port 27017

在MongoShell中执行:

db.fsyncLock()

步骤2:创建文件系统快照

使用LVM快照为例:

lvcreate --size 1G --snapshot --name mongodb_snap /dev/vg0/mongodb

步骤3:解锁次要节点

创建快照后,解锁次要节点:

db.fsyncUnlock()

步骤4:备份快照数据

将快照挂载到目录,并进行备份:

mkdir -p /mnt/mongodb_snap
mount /dev/vg0/mongodb_snap /mnt/mongodb_snap

# 复制快照数据
rsync -av /mnt/mongodb_snap/data/db/ /path/to/backup

# 卸载并删除快照
umount /mnt/mongodb_snap
lvremove -f /dev/vg0/mongodb_snap

方法三:使用第三方工具(如Percona Backup for MongoDB)

Percona Backup for MongoDB (PBM) 支持对MongoDB副本集进行备份,并且可以自动处理集群拓扑和数据一致性。

步骤1:安装PBM

按照官方文档安装PBM:

curl -LO https://github.com/percona/percona-backup-mongodb/releases/download/v1.5.0/pbm-agent-v1.5.0-linux-amd64.tar.gz
tar -xzf pbm-agent-v1.5.0-linux-amd64.tar.gz
sudo mv pbm-agent /usr/local/bin/

步骤2:配置PBM

初始化PBM配置:

pbm config --mongodb-uri "mongodb://username:password@localhost:27017/admin"

配置存储(例如S3):

pbm config --set storage.s3.bucket="your-bucket-name"
pbm config --set storage.s3.credentials.access-key-id="your-access-key"
pbm config --set storage.s3.credentials.secret-access-key="your-secret-key"
pbm config --set storage.s3.region="your-region"

步骤3:进行备份

启动PBM代理并进行备份:

pbm backup

检查备份状态:

pbm status

方法四:结合次要节点和文件系统快照的备份脚本

下面是一个示例脚本,展示如何从次要节点进行文件系统快照备份。

备份脚本示例

#!/bin/bash

# 配置参数
SECONDARY_HOST="secondary_host"
SECONDARY_PORT="27017"
USERNAME="your_username"
PASSWORD="your_password"
AUTH_DB="admin"
VG_NAME="vg0"
LV_NAME="mongodb"
SNAP_NAME="mongodb_snap"
BACKUP_PATH="/path/to/backup/incremental"
DATE=$(date +%Y%m%d_%H%M%S)
SNAP_PATH="/mnt/mongodb_snap"

# 锁定次要节点
mongo --host ${SECONDARY_HOST} --port ${SECONDARY_PORT} -u ${USERNAME} -p ${PASSWORD} --authenticationDatabase ${AUTH_DB} --eval "db.fsyncLock()"

# 创建LVM快照
lvcreate --size 1G --snapshot --name ${SNAP_NAME} /dev/${VG_NAME}/${LV_NAME}

# 解锁次要节点
mongo --host ${SECONDARY_HOST} --port ${SECONDARY_PORT} -u ${USERNAME} -p ${PASSWORD} --authenticationDatabase ${AUTH_DB} --eval "db.fsyncUnlock()"

# 挂载快照
mkdir -p ${SNAP_PATH}
mount /dev/${VG_NAME}/${SNAP_NAME} ${SNAP_PATH}

# 备份增量数据
rsync -av --delete ${SNAP_PATH}/data/db/ ${BACKUP_PATH}/incremental_${DATE}

# 卸载并删除快照
umount ${SNAP_PATH}
lvremove -f /dev/${VG_NAME}/${SNAP_NAME}
rmdir ${SNAP_PATH}

echo "Incremental backup completed: ${BACKUP_PATH}/incremental_${DATE}"

总结

使用副本集进行备份是一种高效、安全的方法,可以减少对主节点的影响。通过不同的技术手段,包括从次要节点备份、使用文件系统快照和第三方工具,可以实现对MongoDB数据的安全、高效备份。根据具体需求选择合适的方法,并定期验证备份和恢复过程,确保数据的安全和可恢复性。