设为首页 加入收藏

TOP

MySQL备份恢复之XtraBackup(三)
2014-11-23 23:18:47 来源: 作者: 【 】 浏览:40
Tags:MySQL 备份 恢复 XtraBackup
缩包

(2) 增量日志备份

由于数据库不停的对外提供服务,备份之后的操作会记录到binlong日志文件中,所以我们还应备份后续的日志文件。

此处删除几张表,并切换日志以模拟真实环境,备份完整的binlog日志文件;然后关闭数据库,删除数据库所有文件,以便模拟故障。

--脚本内容(binlog备份到远程机器):

[root@db xtrabak]# more binlog_bak.sh
cd /var/lib/
DATE=`date -d '-1 hour' +%Y%m%d%H00`
touch -t "${DATE}" starttemp
echo "$DATE"
umount /mnt_log>/dev/null 2>&1
mount -t nfs 192.168.3.108:/logcenter /mnt_log
find /var/lib/mysql/mysql-bin.* -newer starttemp|xargs -I {} cp -p {} /mnt_log/mysql-binlog/192.168.3.28/
# umount -t nfs /mnt_log

(3) 恢复

--脚本内容:

[root@db xtrabak]# more prepare.sh
# 2014-04-30
service mysql stop
mkdir -p /data/xtrabak/prepare_`date +%F`/
tar -ixzvf /data/xtrabak/bak_`date +%F`/base.tar.gz -C /data/xtrabak/prepare_`date +%F`/
innobackupex --apply-log --user=root --defaults-file=/etc/my.cnf /data/xtrabak/prepare_`date +%F`/
innobackupex --copy-back --user=root --defaults-file=/etc/my.cnf /data/xtrabak/prepare_`date +%F`/
chown -R mysql:mysql /var/lib/mysql/
rm -rf /var/lib/mysql/xtrabackup_binlog_pos_innodb
service mysql restart

--完全备份恢复后,通过binlog进行增量恢复

[root@db test]# mysqlbinlog start-position=****** /mnt_log/mysql-binlog/192.168.3.28/mysql-bin.000052 |mysql -uroot -proot123

注意:start-position的位置可通过解压后的备份文件查看,如下:

[root@db xtrabak]# cd prepare_2014-04-30/

[root@db prepare_2014-04-30]# more xtrabackup_binlog_info
mysql-bin.000047 1472

或者

[root@db prepare_2014-04-30]# more xtrabackup_binlog_pos_innodb
./mysql-bin.000047 1472

成功恢复后,MySQL即可正常使用。

首页 上一页 1 2 3 4 5 6 下一页 尾页 3/6/6
】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
分享到: 
上一篇MSSQL查询第五条到第十条数据 下一篇MySQL查询时强制区分大小写

评论

帐  号: 密码: (新用户注册)
验 证 码:
表  情:
内  容: