dba+工具:MongoDB热备份工具,解决官方版备份缺陷
前言目前官方MongoDB社区版是不支持Hot Backup热备份的,我们只能通过mongodump等逻辑备份工具导出bson文件,再mongorestore导入,类似MySQL的mysqldump工具。 在备份副本集时,我们需指定--oplog选项记录备份间产生的增量数据,类似mysqldump --single-transaction --master-data=2(做一致性快照并记录当前的binlog点)。 对副本集的成员恢复,需先切成单机版,mongorestore必须指定--oplogReplay选项,以恢复到某一时刻的快照,最后还需填充oplog(增量数据以哪个位置点开始断点续传),mongorestore -d local -c oplog.rs dump/oplog.bson,最后一步再切为副本集成员重新启动。 中小型数据库备份起来简单快捷,如果过TB级的数据量,那将是痛苦的。 如果你的oplog设置过小,很有可能在备份恢复这段时间,oplog被覆盖重写,那么你将永远无法加入副本集集群里。 概述Percona MongoDB 3.2版本默认开始支持WiredTiger引擎的在线热备份,解决了官方版只能通过mongodump逻辑备份这一缺陷。 参考文献: https://www.percona.com/doc/percona-server-for-mongodb/LATEST/hot-backup.html#hot-backup 注意事项1、要在当前dbpath中对数据库进行热备份,请在admin数据库上以管理员身份运行createBackup命令,并指定备份目录。 2、可以替换一台从库为Percona MongoDB,做备份使用。(我这里实测是Percona MongoDB 3.4版本) 原理Percona MongoDB HotBackup热备份原理: 你可以想象成xtrabackup工具 备份:
恢复:
运行这里我封装了一个PHP脚本,直接在SHELL里运行即可。 1、环境准备:
2、php-mongo驱动安装:
把extension=mongo.so加入到/etc/php.ini最后一行。 3、创建mongodb超级用户权限(备份时使用)
4、修改pmongo_bak.php配置信息
5、前台运行:
6、写入系统crontab里
7、不支持远程备份,需将备份脚本部署在从库里。如果你想把数据备份到远程,可以采用NFS等文件系统mount挂载上。 【编辑推荐】
点赞 0 (编辑:青岛站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |