|
|
51CTO旗下网站
|
|
移动端

dba+工具:MongoDB热备份工具,解决官方版备份缺陷

目前官方MongoDB社区版是不支持Hot Backup热备份的,我们只能通过mongodump等逻辑备份工具导出bson文件,再mongorestore导入,类似MySQL的mysqldump工具。

作者:贺春旸来源:DBAplus社群|2018-12-12 14:15

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工具

备份:

  • 首先会启动一个后台检测的进程,实时检测MongoDB Oplog的变化,一旦发现oplog有新的日志写入,立刻将日志写入到日志文件WiredTiger.backup中(你可以strings WiredTiger.backup查看oplog操作日志的变化);
  • 复制MongoDB dbpath的数据文件和索引文件到指定的备份目录里;
  • ......

恢复:

  • 将WiredTiger.backup日志进行回放,将操作日志变更应用到WiredTiger引擎里,最终得到一致性快照恢复;
  • 把备份目录里的数据文件直接拷贝到你的dbpath下,然后启动MongoDB即可,会www88必发手机接入副本集集群。

运行

这里我封装了一个PHP脚本,直接在SHELL里运行即可。

1、环境准备:

  1. shell> yum install -y php-pear php-devel php gcc openssl openssl-devel cyrus-sasl cyrus-sasl-devel 

2、php-mongo驱动安装:

  1. shell> pecl install mongo 

把extension=mongo.so加入到/etc/php.ini最后一行。

3、创建mongodb超级用户权限(备份时使用)

  1. db.createUser({user:"admin",pwd:"123456",roles:[{role:"root",db:"admin"}]}) 

4、修改pmongo_bak.php配置信息

  1. //*************修改下面的配置信息***************//  
  2. $user = "admin"; //使用root用户权限  
  3. $pwd = '123456';   
  4. $host = '192.168.180.26'; //在从库上热备  
  5. $port = '27017' 
  6. $authdb = 'admin'; //权限认证数据库  
  7. $BAKDIR = "/data/bak/" 
  8. $BAKDIR .= date('Y_m_d_H_i_s');  
  9.  
  10. //*************下面的代码不用修改***************//  
  11. $m = new MongoBak($user,$pwd,$host,$port,$authdb,$BAKDIR);  
  12. ...... 

5、前台运行:

  1. shell> php pmongo_bak.php(以root权限运行) 

6、写入系统crontab里

  1. 00 01 * * * /usr/bin/php /root/php_mongodb/pmongo_bak.php > /root/php_mongodb/bak_status.log 2 >&1 

7、不支持远程备份,需将备份脚本部署在从库里。如果你想把数据备份到远程,可以采用NFS等文件系统mount挂载上。

【编辑推荐】

  1. 黑客攻击数据库的六大手段
  2. 2018年12月全球数据库排行榜:Oracle惨不忍睹!
  3. 免费电子书|MongoDB入门到实践
  4. 记一次生产数据库"意外"重启的经历
  5. ERP技术全接触:数据库、编程和前端技术
【责任编辑:庞桂玉 TEL:(010)68476606】

点赞 0
分享:
大家都在看
猜你喜欢

订阅专栏+88必发官方手机登录

活学活用 Ubuntu Server

活学活用 Ubuntu Server

实战直通车
共35章 | UbuntuServer

218人订阅学习

Java EE速成指南

Java EE速成指南

掌握Java核心
共30章 | 51CTO王波

83人订阅学习

Mysql DBA修炼之路

Mysql DBA修炼之路

MySQL入门到高阶
共24章 | 武凤涛

471人订阅学习

视频课程+88必发官方手机登录

讲师:人学习过

讲师:人学习过

读 书 +88必发官方手机登录

超级网管员——网络应用

本书全面、深入地介绍了网络应用技术,主要内容包括:RMS权限管理服务、Exchange邮件服务、LCS即时消息服务、WSUS系统更新服务、Symantec网...

订阅51CTO邮刊

点击这里查看样刊

订阅51CTO邮刊

51CTO服务号

51CTO播客

博聚网