背景说明
安装
相关准备
创建备份目录
备份实操作
1. 全量备份
innobackupex --user=root --password=123456 --socket=/tmp/mysql_3306.sock --defaults-file=/data/backup/conf/3306.cnf /data/backup/full/
首次将数据库的所有数据备份到/data/backup/full/目录,在/data/backup/full/ 目录下将生成一个当前时间戳的子目录,如图1。若要不生成时间戳的子目录,可以使用--no-timestamp参数,使其不自动生成时间戳的子目录,所以备份数据将存储在/data/backup/full/ 下。 全备只需指定用于备份的用户名、密码和备份路径即可,最后出现innobackupex: completed OK! 则代表备份成功。
图1
全备后的目录文件,如图2。
图2
对比mysql的data目录下的文件,如图3。
图3
文件说明:
backup-my.cnf: 主要是记录innobackupex中使用到Mysql参数。
[root@h199 2014-11-07_14-06-47]# cat backup-my.cnf # This MySQL options file was generated by innobackupex. # The MySQL server [mysqld] innodb_checksum_algorithm=innodb innodb_data_file_path=ibdata1:12M:autoextend innodb_log_files_in_group=2 innodb_log_file_size=50331648 innodb_page_size=16384 innodb_undo_directory=. innodb_undo_tablespaces=0 |
xtrabackup_checkpoints: 记录备份类型及开始及结束的lsn位置。backup_type 有两种full-prepared (全备)、incremental (增备)
[root@h199 2014-11-07_14-06-47]# cat xtrabackup_checkpoints backup_type = full-prepared from_lsn = 0 to_lsn = 8234580547 last_lsn = 8234580547 compact = 0 |
xtrabackup_info: 记录mysql相关信息
[root@h199 2014-11-07_14-06-47]# cat xtrabackup_info uuid = 3d090541-6649-11e4-bb2a-000c295bd3a3 name = tool_name = innobackupex tool_command = --user=root --password=... --incremental /data/backup/incremental/ --incremental-base=/data/backup/incremental/2014-11-07_14-24-54/ --defaults-file =/data/backup/conf/3306.cnf --socket=/tmp/mysql_3306.sock tool_version = 1.5.1-xtrabackup ibbackup_version = xtrabackup version 2.2.6 based on MySQL server 5.6.21 Linux (x86_64) (revision id: ) server_version = 5.6.21-log start_time = 2014-11-07 14:41:52 end_time = 2014-11-07 14:42:27 lock_time = 2 binlog_pos = innodb_from_lsn = 8234579864 innodb_to_lsn = 8234580547 partial = N incremental = Y format = file compact = N compressed = N |
xtrabackup_logfile: xtrabackup自己的日志文件,新版本中不直接可见
2.制造新数据
创建表,并写入数据,作为新增的数据。
use test;
create table t3(col1 int,col2 int);
写入新数据
insert into t3(col1,col2)value(1,1);
insert into t3(col1,col2)value(2,1);
insert 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. 第一次增量备份
[root@h199 2014-11-07_14-21-25]# cat backup-my.cnf # This MySQL options file was generated by innobackupex. # The MySQL server [mysqld] innodb_checksum_algorithm=innodb innodb_data_file_path=ibdata1:12M:autoextend innodb_log_files_in_group=2 innodb_log_file_size=50331648 innodb_page_size=16384 innodb_undo_directory=. innodb_undo_tablespaces=0 |
[root@h199 2014-11-07_14-21-25]# cat backup-my.cnf # This MySQL options file was generated by innobackupex. # The MySQL server [mysqld] innodb_checksum_algorithm=innodb innodb_data_file_path=ibdata1:12M:autoextend innodb_log_files_in_group=2 innodb_log_file_size=50331648 innodb_page_size=16384 innodb_undo_directory=. innodb_undo_tablespaces=0 |
[root@h199 2014-11-07_14-21-25]# cat xtrabackup_info uuid = 5fba7b1b-6646-11e4-bb2a-000c295bd3a3 name = tool_name = innobackupex tool_command = --user=root --password=... --defaults-file=/data/backup/conf/3306.cnf --socket=/tmp/mysql_3306.sock --incremental /data/backup/incremental/ --incremental-basedir=/data/backup/full/2014-11-07_14-06-47/ tool_version = 1.5.1-xtrabackup ibbackup_version = xtrabackup version 2.2.6 based on MySQL server 5.6.21 Linux (x86_64) (revision id: ) server_version = 5.6.21-log start_time = 2014-11-07 14:21:25 end_time = 2014-11-07 14:21:56 lock_time = 1 binlog_pos = innodb_from_lsn = 8234574477 innodb_to_lsn = 8234578623 partial = N incremental = Y format = file compact = N compressed = N |
3.再新增数据,准备第三次备份
insert into t3(col1,col2)value(11,1); insert into t3(col1,col2)value(12,1); insert into t3(col1,col2)value(13,1); insert into t3(col1,col2)value(14,1); insert into t3(col1,col2)value(15,1); insert into t3(col1,col2)value(16,1); insert into t3(col1,col2)value(17,1); insert into t3(col1,col2)value(18,1); insert into t3(col1,col2)value(19,1); insert into t3(col1,col2)value(20,1); |
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
完成后查看/data/backup/incremental目录下是否新增2014-11-07_14-21-25目录
了解两个参数
--apply-log :创建新的事务日志,从backup-my.cnf文件中读取innodb配置信息。
--redo-only:只读已提交的事务,在最后一次增量合并时,不需要填写这个参数。
7.将第二次做的增量备份数据进行合并到全备份中去
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参数。
8. 恢复时需要停掉MySQL,所以我们停掉MySQL3307实例。
/usr/local/mysql/bin/mysqld_multi stop 3307
如果无法停止mysql,执行kill -9 mysql3307实例的进程
9. 恢复数据。注意这里指定的文件夹是2013-09-10_22-12-50
innobackupex --defaults-file=/data/backup/conf/3307.cnf --copy-back /data/backup/full/2014-11-06_14-52-38/
10. mysql的data目录进行权限设置
chown -R mysql:mysql /data/mysql/mysql_3307/data
11.启动mysql3307实例
/usr/local/mysql/bin/mysqld_mutil start 3306
查看实例是否被启动:
/usr/local/mysql/bin/mysqld_mutil report
12.登录数据库核对两个数据库中相关表的数据是否一致。
另外也可以通过这个备份恢复3306的数据,通过如下操作模拟数据丢失情况。
1 .模拟数据丢失
drop database test
2. 停止3306实例
3. 通过上次的全备+增备1+增备2的数据恢复3306实例的test数据库。
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
图7
查看下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 engine: InnoDB 2014-11-07 10:24:05 12406 [ERROR] Aborting |