前言:html
目前官方MongoDB社区版是不支持Hot Backup热备份的,咱们只能经过mongodump等逻辑备份工具导出bson文件,再mongorestore导入,相似MySQL的mysqldump工具。mysql
在备份副本集时,咱们需指定--oplog选项记录备份间产生的增量数据,相似mysqldump --single-transaction --master-data=2(作一致性快照并记录当前的binlog点)。git
对副本集的成员恢复,需先切成单机版,mongorestore必须指定--oplogReplay选项,以恢复到某一时刻的快照,最后还需填充oplog(增量数据以哪一个位置点开始断点续传),mongorestore -d local -c oplog.rs dump/oplog.bson,最后一步再切为副本集成员从新启动。github
中小型数据库备份起来简单快捷,若是过TB级的数据量,那将是痛苦的。sql
若是你的oplog设置太小,颇有可能在备份恢复这段时间,oplog被覆盖重写,那么你将永远没法加入副本集集群里。mongodb
概述:shell
Percona MongoDB3.2版本默认开始支持WiredTiger引擎的在线热备份,解决了官方版只能经过mongodump逻辑备份这一缺陷。数据库
参考文献:ide
https://www.percona.com/doc/percona-server-for-mongodb/LATEST/hot-backup.html#hot-backup
注意事项:
一、要在当前dbpath中对数据库进行热备份,请在admin数据库上以管理员身份运行createBackup命令,并指定备份目录。
二、能够替换一台从库为Percona MongoDB,作备份使用。(我这里实测是Percona MongoDB 3.4版本)
Percona MongoDB HotBackup热备份原理:
你能够想象成xtrabackup工具
备份:
一、首先会启动一个后台检测的进程,实时检测MongoDB Oplog的变化,一旦发现oplog有新的日志写入,马上将日志写入到日志文件WiredTiger.backup中(你能够strings WiredTiger.backup查看oplog操做日志的变化);
二、复制MongoDB dbpath的数据文件和索引文件到指定的备份目录里。
......
恢复:
一、将WiredTiger.backup日志进行回放,将操做日志变动应用到WiredTiger引擎里,最终获得一致性快照恢复。
二、把备份目录里的数据文件直接拷贝到你的dbpath下,而后启动MongoDB便可,会自动接入副本集集群。
这里我封装了一个PHP脚本,直接在SHELL里运行便可。
一、环境准备:
shell> yum install -y php-pear php-devel php gcc openssl openssl-devel cyrus-sasl cyrus-sasl-devel
二、php-mongo驱动安装:
shell> pecl install mongo
把extension=mongo.so加入到/etc/php.ini最后一行。
三、建立mongodb超级用户权限(备份时使用)
db.createUser({user:"admin",pwd:"123456",roles:[{role:"root",db:"admin"}]})
四、修改pmongo_bak.php配置信息
//修改下面的配置信息**//
$user = "admin"; //使用root用户权限
$pwd = '123456';
$host = '192.168.180.26'; //在从库上热备
$port = '27017';
$authdb = 'admin'; //权限认证数据库
$BAKDIR = "/data/bak/";
$BAKDIR .= date('Y_m_d_H_i_s');
//下面的代码不用修改**//
$m = new MongoBak($user,$pwd,$host,$port,$authdb,$BAKDIR);
......
五、前台运行:
shell> php pmongo_bak.php(以root权限运行)
六、写入系统crontab里
00 01 * * * /usr/bin/php /root/php_mongodb/pmongo_bak.php > /root/php_mongodb/bak_status.log 2 >&1
七、不支持远程备份,需将备份脚本部署在从库里。若是你想把数据备份到远程,能够采用NFS等文件系统mount挂载上。
下载地址: