nsert into t3(col1,col2)value(3,1);
insert into t3(col1,col2)value(4,1);
insert into t3(col1,col2)value(5,1);
insert into t3(col1,col2)value(6,1);
insert into t3(col1,col2)value(7,1);
insert into t3(col1,col2)value(8,1);
insert into t3(col1,col2)value(9,1);
insert into t3(col1,col2)value(10,1);
注:可以删除、更新数据,再观察首次增量备份后的目录下的表文件,与全量备份的表文件进行对比,分析不同之处。
3. 第一次增量备份
第二次备份即首次增量备份,增量备份是在上次备份的基础上对最新的数据进行备份。语句如下:
innobackupex --user=root --password=123456 --socket=/tmp/mysql_3306.sock --defaults-file=/data/backup/conf/3306.cnf --incremental /data/backup/incremental/ --incremental-basedir=/data/backup/full/2014-11-07_14-06-47
参数说明:
--incremental :指定存储本次增量备份的目录
--incremental-basedir:上次备份的存储目录
完成首次的增量备份后,在指定目录下也会生成一个新的目录,目录中的文件与全量备份文件部分不一样。
4. 第二次增量备份
在第二次备份(增备)的基础上,再进行备份。
innobackupex --user=root --password=123456 --socket=/tmp/mysql_3306.sock --defaults-file=/data/backup/conf/3306.cnf --incremental /data/backup/incremental/ --incremental-basedir=/data/backup/incremental/2014-11-07_14-21-25
恢复操作
1. 对全量备份进行操作
了解两个参数 :
--apply-log :创建新的事务日志,从backup-my.cnf文件中读取innodb配置信息。
--redo-only:只读已提交的事务,在最后一次增量合并时,不需要填写这个参数。
全量备份恢复前准备
innobackupex --apply-log --redo-only /data/backup/full/2014-11-07_14-06-47
2. 将第一次增量备份的数据合并到全量备份中
innobackupex --apply-log --redo-only /data/backup/full/2014-11-07_14-06-47 --incremental-dir=/data/backup/incremental/2014-11-07_14-21-25
3.将第二次全量备份的数据合并到全量备份中
innobackupex --apply-log /data/backup/full/2014-11-06_14-52-38/ --incremental-dir=/data/backup/incremental/2014-11-07_14-23-52
注:最后一次的合并操作中不需要添加--redo-only参数。
4.停止mysql服务
恢复时需要停掉MySQL,所以我们停掉MySQL3307实例。
/usr/local/mysql/bin/mysqld_multi stop 3307
如果无法停止mysql,执行kill -9 mysql3307实例的进程。
5. 恢复数据。
innobackupex --defaults-file=/data/backup/conf/3307.cnf --copy-back /data/backup/full/2014-11-06_14-52-38/
6.权限设置
对mysql的data目录进行权限设置。
chown -R mysql:mysql /data/mysql/mysql_3307/data
7.启动mysql3307实例
/usr/local/mysql/bin/mysqld_mutil start 3306
查看实例是否被启动:
/usr/local/mysql/bin/mysqld_mutil report
8. 查看是否恢复成功
登录数据库核对两个数据库中相关表的数据是否一致。
另外也可以通过这个备份恢复3306的数据,通过如下操作模拟数据丢失情况。
1 .模拟数据丢失
drop database test;
2. 停止3306实例
3.恢复数据
innobackupex --defaults-file=/data/backup/conf/3306.cnf --copy-back /data/backup/full/2014-11-06_14-52-38/
4. mysql的data目录进行权限设置
chown -R mysql:mysql /data/mysql/mysql_3307/data
5.启动3306实例
查看test数据库是所有表及数据都被恢复。
注:
1. 在备份的时候如果磁盘空间还足够的话,建议每个备份都再做一个副本,防止备份数据异常。
2. 进行恢复的时候一定要注意合并的先后顺序,如全备->增量备2->增量备份2,先后顺序不能乱,否则将使用数据不一致。
碰到的问题及解决方法
1. innobackupex: Error: Original data directory 'XXX' is not empty!
需要删除之前的data目录下的,我们可以对原有的data目录进行重命名。
mv /data/mysql/mysql_3307/data /data/mysql/mysql_3307/data_bak_20141107
2. ./ibdata1 can't be opened in read-write mode

图4
查看下data及子目录的所属用户及用户组,如果是root用户及用户组,可以做如下操作:
chown -R mysql:mysql /data/mysql/mysql_3307/data
3.InnoDB: Cannot create ./ib_logfile101
如下错误:
| 2014-11-07 10:24:05 12406 [ERROR] InnoDB: Cannot create ./ib_logfile101 2014-11-07 10:24:05 12406 [ERROR] Plugin 'InnoDB' init function returned error. 2014-11-07 10:24:05 12406 [ERROR] Plugin 'InnoDB' registration as a STORAGE ENGINE failed. 2014-11-07 10:24:05 12406 [ERROR] Unknown/unsupported storage eng |