mysql 增量备份_MySQL Xtrabackup备份恢复

本文介绍PerconaXtrabackup这一开源、免费的MySQL物理热备份工具,涵盖其安装、使用方法及增量备份恢复流程。PerconaXtrabackup能实现非阻塞备份,支持增量备份,相较于mysqldump,它在大数据量下的恢复速度更快。

Percona Xtrabackup 备份恢复工具简介

目前MySQL物理备份工具主要有MySQL官方提供的MySQL Enterprise Backup(MEB) 以及Percona xbackackup,MySQL Enterprise Backup为商业工具,MySQL8.0以后,Percona xbackackup也相应提供了8.0版本,语法略微有差别,后续更新xbackackup8.0版本,Percona xbackackup是世界上唯一的开源、免费的MySQL物理热备份软件,可以为InnoDB和XtraDB数据库执行非阻塞备份。Xbackackup有如下好处:

恢复时间相对mysqldump快很多

大数据量下异机恢复特别快

支持增量备份恢复

备份期间不间断的事务处理

节省磁盘空间和网络带宽

自动备份验证

Percona Xtrabackup 安装

Percona xbackackup安装方式有很多种,此处以yum源安装为例演示(yum源根据需求下载) Xtrabackup包依赖于epel源一些工具包,推荐使用yum安装。

yum install http://www.percona.com/downloads/percona-release/redhat/0.1-4/percona-release-0.1-4.noarch.rpm

安装Percona xbackackup

Percona Xtrabackup 完整备份

由于Percona Xtrabackup备份参数比较多,需要自己去学习,此处只是作为演示全库备份恢复。创建备份用户:(正常生产环境都不会直接采用root用户备份,需要新建备份用户,用于数据定期备份)

mysql> CREATE USER 'bkpuser'@'localhost' IDENTIFIED BY 's3cret';

mysql> GRANT RELOAD, LOCK TABLES, PROCESS, REPLICATION CLIENT ON *.* TO

       'bkpuser'@'localhost';

mysql> FLUSH PRIVILEGES;

a79f4e79fc09ec58a8c3b32caf152f80.png

当前数据库状态:

完全备份数据库:

XtraBackup 在备份的时候并不锁定表,而是一页一页地复制 InnoDB 的数据,与此同时,XtraBackup 还有另外一个线程监视着 transactions log,一旦 log 发生变化,就把变化过的 log pages 复制走。在全部数据文件复制完成之后,停止复制 logfile。

innobackupex --defaults-file=/home/mysqldata/mysql-sandboxes/3310/my.cnf --host=10.1.101.45 --user=root --password=RL_air2016dbit --port=3310 --no-timestamp /home/yunwei/full_20180607_back

注--no-timestamp 该参数的含义:不需要系统创建时间目录,自己可以命名;

当出现completed OK 表示备份完成

f81b6f658643081ce2b44964a667cdd7.png

备份数据目录:

1ad10694cb844a0565b01ecd8dc13030.png

Percona Xtrabackup 完整备份恢复

恢复前准备

一般情况下,在备份完成后,数据尚且不能用于恢复操作,因为备份的数据中可能会包含尚未提交的事务或已经提交但尚未同步至数据文件中的事务。因此,此时数据文件仍处理不一致状态。

“准备”的机制:通过回滚未提交的事务及同步已经提交的事务至数据文件也使得数据文件处于一致性状态。

数据恢复

1.将备份数据和/etc/my.cnf文件拷贝到目标机器

2.不要启动数据库,开始恢复前的准备工作

innobackupex --apply-log --redo-only /home/yunwei/full_20180607_back

3.恢复数据

innobackupex --copy-back --datadir=/root/mysql-sandboxes/3310/sandboxdata/  /home/yunwei/full_20180607_back

注:1.请确保数据目录/root/mysql-sandboxes/3311/sandboxdata为空之后拷贝

2.确保拷贝时候实例处于down状态

4.启动数据库

/root/mysql-sandboxes/3311/mysqld --defaults-file=/root/mysql-sandboxes/3311/my.cnf --user=root  &

增量备份

增备原理分析

在完整备份和增量备份文件中都有一个文件 xtrabackup_checkpoints 会记录备份完成时检查点的LSN。在进行新的增量备份时,XtraBackup 会比较表空间中每页的 LSN 是否大于上次备份完成的 LSN,如果是,则备份该页,并记录当前检查点的 LSN。

全量备份信息:

[root@localhost full_20180607_back]# cat xtrabackup_checkpoints

backup_type = log-applied

from_lsn = 0

to_lsn = 13044860446

last_lsn = 13044860455

compact = 0

recover_binlog_info = 0

修改数据,并执行第一次增量备份

innobackupex --defaults-file=/home/mysqldata/mysql-sandboxes/3310/my.cnf --host=10.1.101.45 --user=root --password=RL_air2016dbit --port=3310 --no-timestamp --incremental  --incremental-basedir=/home/yunwei/full_20180607_back /home/yunwei/full_20180607_back/incre_1

再次修改数据,执行第二次增量备份

innobackupex --defaults-file=/home/mysqldata/mysql-sandboxes/3310/my.cnf --host=10.1.101.45 --user=root --password=RL_air2016dbit --port=3310 --no-timestamp --incremental  --incremental-basedir=/home/yunwei/full_20180607_back/incre_1 /home/yunwei/full_20180607_back/incre_2

 查看数据目录

[root@localhost yunwei]# tree full_20180607_back/ -d

full_20180607_back/

├── dfafda

├── helloword

├── hfhdajdf

├── incre_1

│   ├── dfafda

│   ├── hellowd

│   ├── helloword

│   ├── hfhdajdf

│   ├── MessageCenter

│   ├── mysql

│   ├── otter

│   ├── performance_schema

│   ├── retl

│   ├── sys

│   ├── test

│   └── word

├── incre_2

│   ├── dfafda

│   ├── hellowd

│   ├── helloword

│   ├── hfhdajdf

│   ├── MessageCenter

│   ├── mysql

│   ├── otter

│   ├── performance_schema

│   ├── retl

│   ├── sys

│   ├── test

│   └── word

├── MessageCenter

├── mysql

├── otter

├── performance_schema

├── retl

├── sys

├── test

└── word

增量恢复

增量备份恢复需要全量备份为基础,如果没有全量备份进行增量备份是毫无意义的,完整备份集=全备+增备1+增备2+增量n,进行增量恢复时候,也需要像全备一样进行应用日志,保证数据一致,并将增量数据合并到全备中。

将第一次增量合并到全量中

innobackupex --apply-log --redo-only /home/yunwei/full_20180607_back/ --incremental-dir=/home/yunwei/full_20180607_back/incre_1/

将第二次增量合并到全量中

innobackupex --apply-log --redo-only /home/yunwei/full_20180607_back/ --incremental-dir=/home/yunwei/full_20180607_back/incre_2/

恢复数据

innobackupex --copy-back --datadir=/root/mysql-sandboxes/3310/sandboxdata/  /home/yunwei/full_20180607_back

检查数据

a9161139e15efafea7551c5fe9d49e1a.png

自动备份脚本

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值