系统版本RHEL6.6
MySQL版本 5.5.28-i386
XtraBackup-2.2.9
Percona XtraBackup是一块开源且免费的对MySQL Innodb存储引擎备份数据的工具,使用此工具的时候不需停止MySQL,而且支持压缩备份,支持对Innodb存储引擎做增量备份,对MYISAM存储引擎做完全备份,并且支持流备份。
使用innobakupex备份时,其会调用xtrabackup备份所有的InnoDB表,复制所有关于表结构定义的相关文件(.frm)、以及MyISAM、MERGE、CSV和ARCHIVE表的相关文件,同时还会备份触发器和数据库配置信息相关的文件。这些文件会被保存至一个以时间命令的目录中。
在备份的同时,innobackupex还会在备份目录中创建如下文件:
(1)xtrabackup_checkpoints ―― 备份类型(如完全或增量)、备份状态(如是否已经为prepared状态)和LSN(日志序列号)范围信息;
每个InnoDB页(通常为16k大小)都会包含一个日志序列号,即LSN。LSN是整个数据库系统的系统版本号,每个页面相关的LSN能够表明此页面最近是如何发生改变的。
(2)xtrabackup_binlog_info ―― mysql服务器当前正在使用的二进制日志文件及至备份这一刻为止二进制日志事件的位置。
(3)xtrabackup_binlog_pos_innodb ―― 二进制日志文件及用于InnoDB或XtraDB表的二进制日志文件的当前position。
(4)xtrabackup_binary ―― 备份中用到的xtrabackup的可执行文件;
(5)backup-my.cnf ―― 备份配置文件
步骤一:下载安装
先去官网下载对应版本的XtraBackup的rpm包
官网地址:http://www.percona.com
[root@localhost ~]# rpm -ivhpercona-xtrabackup-2.2.9-5067.el6.i686.rpm
warning:percona-xtrabackup-2.2.9-5067.el6.i686.rpm: Header V4 DSA/SHA1 Signature, keyID cd2efd2a: NOKEY
error: Failed dependencies:
perl(DBD::mysql)is needed by percona-xtrabackup-2.2.9-5067.el6.i686
perl(Time::HiRes)is needed by percona-xtrabackup-2.2.9-5067.el6.i686
出现错误,需要手动解决依赖关系,解决办法:
[root@localhost ~]# yum -y install perl-Time-HiRes perl-DBD-MySQL
[root@localhost~]# rpm -ivh percona-xtrabackup-2.2.9-5067.el6.i686.rpm
步骤二:完全备份
把数据备份到/backup目录,备份完成后,在/backup目录下生成以当前时间命名的备份文件。
[root@localhost ~]# innobackupex --user=root /backup
[root@localhost ~]# ls /backup/
2015-03-22_20-16-17
步骤三:准备完全备份
在备份完成后,数据还不能用于恢复操作,因为备份的数据中可能会包含尚未提交的事务或已经提交但尚未同步至数据文件中的事务。因此要做一个准备工作。
使用--apply-log选项 ,指定完全备份目录。
[root@localhost ~]# innobackupex --apply-log /backup/2015-03-22_20-16-17/
步骤四:模拟用户写入数据
mysql> SHOW DATABASES;
+--------------------+
| Database |
+--------------------+
| information_schema |
| mysql |
| performance_schema |
| school |
+--------------------+
mysql> use school;
mysql> SHOW TABLES;
+------------------+
| Tables_in_school |
+------------------+
| student |
+------------------+
mysql> SELECT * FROM student;
+----+--------------------+---------------+
| ID | Name | Course |
+----+--------------------+---------------+
| 1 | xiaoming | English |
| 2 | xiaohong | Kuihuabaodian |
| 3 | www.mingxiao.info | |
| 4 | www.mingxiao.info1 | |
+----+--------------------+---------------+
mysql> INSERT INTO student (Name) VALUES ('xiaohei'),('xiaoqing');
Query OK, 2 rows affected, 1 warning (0.01 sec)
Records: 2 Duplicates: 0 Warnings: 1
插入以后结果:
mysql> SELECT * FROM student;
+----+--------------------+---------------+
| ID | Name | Course |
+----+--------------------+---------------+
| 1 | xiaoming | English |
| 2 | xiaohong | Kuihuabaodian |
| 3 | www.mingxiao.info | |
| 4 | www.mingxiao.info1 | |
| 5 | xiaohei | |
| 6 | xiaoqing | |
+----+--------------------+---------------+
更新二进制日志文件
mysql> FLUSH LOGS;
Query OK, 0 rows affected (0.01 sec)
mysql> SHOW MASTER LOGS;
+------------------+-----------+
| Log_name | File_size |
+------------------+-----------+
| mysql-bin.000001 | 398 |
| mysql-bin.000002 | 107 |
+------------------+-----------+
2 rows in set (0.00 sec)
备份二进制日志文件,用于及时点复原
[root@localhost data]# mysqlbinlog --start-position=107 /mydata/data/mysql-bin.000001 > /backup/BIN_LOG.sql
步骤五:模拟MySQL损坏
service mysqld stop
[root@localhost ~]# rm -rf /mydata/data/*
步骤六:恢复数据
[root@localhost ~]# innobackupex --copy-back /backup/2015-03-22_20-16-17/
此时数据目录/mydata/data中数据属主和属组都是root用户root组,需要改为mysql用户mysql组。改完以后就可以启动mysqld服务。
[root@localhost data]# chown -R mysql.mysql /mydata/data/*
[root@localhost data]# service mysqld start
Starting MySQL.. SUCCESS!
连上mysql,可看到刚刚插入表中的数据不存在,因此需要用二进制日志做及时点还原。
mysql> USE school;
Database changed
mysql> SELECT * FROM student;
+----+--------------------+---------------+
| ID | Name | Course |
+----+--------------------+---------------+
| 1 | xiaoming | English |
| 2 | xiaohong | Kuihuabaodian |
| 3 | www.mingxiao.info | |
| 4 | www.mingxiao.info1 | |
+----+--------------------+---------------+
4 rows in set (0.00 sec)
mysql> SET sql_log_bin=0; 关闭二进制日志文件功能
Query OK, 0 rows affected (0.00 sec)
mysql> SOURCE /backup/BIN_LOG.sql; 及时点还原
mysql> SET sql_log_bin=1; 开启二进制日志文件功能
Query OK, 0 rows affected (0.00 sec)
mysql> SELECT * FROM student;
+----+--------------------+---------------+
| ID | Name | Course |
+----+--------------------+---------------+
| 1 | xiaoming | English |
| 2 | xiaohong | Kuihuabaodian |
| 3 | www.mingxiao.info | |
| 4 | www.mingxiao.info1 | |
| 5 | xiaohei | |
| 6 | xiaoqing | |
+----+--------------------+---------------+
6 rows in set (0.00 sec)
可看到原先插入的数据也已经回复。
至此,所有操作已经完成。