1、xtrabackup使用范围

xtrabackup:用于热备份innodb, xtradb引擎的数据表,不能备份其他类型的表,也不能备份数据表结构;

innobackupex:将xtrabackup进行封装的perl脚本,提供了备份myisam表的能力(主要应用该脚本)。


2、xtrabackup的安装

wget https://www.percona.com/downloads/XtraBackup/XtraBackup-2.1.2/RPM/rhel6/i686/percona-xtrabackup-2.1.2-612.rhel6.i686.rp 


rpm -ivh percona-xtrabackup-2.1.2-612.rhel6.i686.rpm 

说明:rpm安装的依赖包根据提醒安装既可。


3、安装好软件后,就可以直接使用

eg1:完整备份数据库

innobackupex --user=root --password=xxxxx --defaults-file=/etc/my.cnf --database=phpcms /mybak/


说明:

/etc/my.cnf,需要配置datadir路径

[mysqld]

datadir = /usr/local/mysql/data   #在[mysqld]单元末尾中添加数据库存放的文件

---------------------------------------------------------------------------

--database=phpcms #表示需要备份的数据库,如果不加表示备份所有数据库(既完整备份)

/tmp/             #备份的目标位置

---------------------------------------------------------------------------

[root@mysql 2015-10-19_21-06-56]# ll                          #备份的信息

total 18468

-rw-r--r-- 1 root root      260 Oct 19 21:06 backup-my.cnf

-rw-r----- 1 root root 18874368 Oct 19 21:06 ibdata1

drwxr-xr-x 2 root root    16384 Oct 19 21:06 phpcms

-rw-r--r-- 1 root root       13 Oct 19 21:06 xtrabackup_binary

-rw-r--r-- 1 root root       23 Oct 19 21:06 xtrabackup_binlog_info

-rw-r----- 1 root root       89 Oct 19 21:06 xtrabackup_checkpoints

-rw-r----- 1 root root     2560 Oct 19 21:06 xtrabackup_logfile


eg2:备份打包

innobackupex --user=root --password=xxxxxxx --defaults-file=/etc/my.cnf --database=phpcms --stream=tar /mybak > /mybak/phpcms.tar 


说明:

--stream=tar #表示打包方式


eg3:完整备份并打包压缩

innobackupex --user=root --password=xxxxxxx --defaults-file=/etc/my.cnf --database=phpcms --stream=tar /mybak/ | gzip > /mybak/phpcms.tar.gz 


eg4:远程备份打包

innobackupex --user=root --password=xxxxxx --defaults-file=/etc/my.cnf --database=phpcms --stream=tar /mybak/ | ssh [email protected] cat ">"  /tmp/phpcms.tar


说明:

[email protected]'s password: >> log scanned up to (1668412)

[01] Streaming ./ibdata1

>> log scanned up to (1668412)

>> log scanned up to (1668412)

>> log scanned up to (1668412)   #一直在不断扫描,在这期间需输入远程备份主机的密码(现实环境还是通过证书验收)


eg5:增量备份

innobackupex --user=root --password=xxxxxx --database=phpcms --incremental 

--incremental-basedir=/mybak/2015-10-19_21-06-56/ /mybak/add/  


#增量备份主要是通过lsn的表示进行判断(针对innodb引擎

[root@mysql 2015-10-19_21-06-56]# cat xtrabackup_checkpoints 

backup_type = full-prepared           #全局备份

from_lsn = 0

to_lsn = 1668412

last_lsn = 1668412                    #结束位置

compact = 0


[root@mysql 2015-10-19_21-48-20]# cat xtrabackup_checkpoints

backup_type = incremental            #增量备份

from_lsn = 1668412                   #“开始位置”和上面“结束位置”一致

to_lsn = 1768416

last_lsn =1768416 

compact = 0


说明:

注意:innobackupex 增量备份仅针对InnoDB这类支持事务的引擎,对于MyISAM等引擎,则仍然是全备。



4、数据还原

eg1:完整备份恢复


第一步:删除需要恢复得数据库

/etc/init.d/mysql stop

mv /usr/local/mysql/data/ /usr/local/mysql/data/

mkdir /usr/local/mysql/data/                    #恢复得时候,该目录必须为空


第二步:然后将备份文件中的日志应用到备份文件中的数据文件


innobackupex --user=root --password=xxxxxx --defaults-file=/etc/my.cnf --apply-log /mybak/2015-10-19_21-06-56/  


这里的--apply-log指明是将日志应用到数据文件上,完成之后将备份文件中的数据恢复到数据库中:

--defaults-file:数据还原的目标位置


innobackupex --user=root --password=xxxxxx --defaults-file=/etc/my.cnf --copy-back /mybak/2015-10-19_21-06-56/   

--copy-back指明是进行数据恢复。数据恢复完成之后,需要修改相关文件的权限mysql数据库才能正常启动。


chown -R mysql:mysql /usr/local/mysql/data/

service mysql start  


    注意:如果数据在远程主机上,首先将完整备份复制到本地主机上,如果是tar包,则需要先解包,解包命令为:tar –izxvf dbbackup20110809.tar,这里必须使用-i参数。然后执行恢复操作。


eg2:恢复单个数据库

1、cp /etc/my.cnf /mybak/

2、vim /mybak/my.cnf

3、vim /mybak/my.cnf 

datadir = /usr/local/mysql/data/phpcms   #确保该目录为空

4、然后执行如下操作

innobackupex --user=root --password=xxxxxx --defaults-file=/mybak/my.cnf --apply-log /mybak/2015-10-19_21-06-56/  

innobackupex --user=root --password=xxxxxx --defaults-file=/mybak/my.cnf --copy-back /mybak/2015-10-19_21-06-56/ 

5、将恢复后的数据,copy到指定的目录即可  


eg3:增量备份恢复:


增量备份恢复的步骤和完整备份恢复的步骤基本一致,只是应用日志的过程稍有不同。增量备份恢复时,是先将所有的增量备份挨个应用到完整备份的数据文件中,然后再将完整备份中的数据恢复到数据库中。命令如下:


应用第一个增量备份

innobackupex --user=root --password=xxxxxx --defaults-file=/etc/my.cnf --apply-log /mybak/2015-10-19_21-06-56/ --incremental-dir=/mybak/add/2015-10-19_21-48-20/  

应用第二个增量备份

innobackupex --user=root --password=xxxxxx --defaults-file=/etc/my.cnf --apply-log /mybak/2015-10-19_21-06-56/ --incremental-dir=/mybak/add/2015-10-19_21-48-54/  

将完整备份中的数据恢复到数据库中

innobackupex --user=root --password=xxxxxx --defaults-file=/etc/my.cnf --copy-back /mysqlbackup/full/2015-10-19_21-06-56/  

其中,--incremental-dir指定要恢复的增量备份的位置