mysql怎么增量备份和恢复数据
这篇文章主要介绍"mysql怎么增量备份和恢复数据",在日常操作中,相信很多人在mysql怎么增量备份和恢复数据问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答"mysql怎么增量备份和恢复数据"的疑惑有所帮助!接下来,请跟着小编一起来学习吧!
全备:
[root@L112 backup]# innobackupex --defaults-file=/etc/my.cnf --no-timestamp --user=root --password=123456 --socket=/var/lib/mysql/mysql.sock /backup/mysqldump/full/back_26-05-2017
增量备份1
(以上次的全备为基础),备份子目录在back_26-05-2017下面
[root@L112 backup]#innobackupex --defaults-file=/etc/my.cnf --no-timestamp --user=root --password=123456 --socket=/var/lib/mysql/mysql.sock --incremental /backup/mysqldump/incremental/back_26-05-2017
--incremental-basedir=/backup/mysqldump/full/back_26-05-2017
增量备份2
(以上一次的增量备份back_26-05-2017为基础),备份子目录在back_27-05-2017下面:
[root@L112 backup]#innobackupex --defaults-file=/etc/my.cnf --no-timestamp --user=root --password=123456 --socket=/var/lib/mysql/mysql.sock --incremental /backup/mysqldump/incremental/back_27-05-2017
--incremental-basedir=/backup/mysqldump/incremental/back_26-05-2017
查看备份的结果:
全备:
[root@L112 full]# ll
total 0
drwxr-xr-x. 6 root root 188 May 26 16:33 back_26-05-2017
增量备份两个:
[root@L112 incremental]# ll
total 0
drwxr-xr-x. 6 root root 214 May 26 09:42 back_26-05-2017
drwxr-xr-x. 6 root root 214 May 27 15:27 back_27-05-2017
下面模拟数据丢失的情况:
删除liuwenhe库
mysql> show databases;
+--------------------+
| Database |
+--------------------+
| information_schema |
| liuwenhe |
| mysql |
| performance_schema |
| test |
+--------------------+
5 rows in set (0.00 sec)
mysql> drop database liuwenhe;
Query OK, 2 rows affected (0.05 sec)
mysql> show databases;
+--------------------+
| Database |
+--------------------+
| information_schema |
| mysql |
| performance_schema |
| test |
+--------------------+
4 rows in set (0.00 sec)
如上所示,liuwenhe库已经被删除掉了。
下面展示具体恢复的过程。。。。。。。。
恢复:
整个过程分为三步骤,整体上可以理解为:先把增量备份的数据倒进全备份中,然后最后使用全备份恢复即可,
第一步:是在所有备份目录下重做已提交的日志,注意最后一个增量备份是没有--redo-only的,并且数据最后是在全备份中,如:
innobackupex --apply-log --redo-only BASE-DIR
innobackupex --apply-log --redo-only BASE-DIR --incremental-dir=INCREMENTAL-DIR-1
innobackupex --apply-log BASE-DIR --incremental-dir=INCREMENTAL-DIR-2
或者
加上用户名和密码,以及使用的配置文件:
innobackupex --defaults-file=/opt/mysql/my.cnf --user=root --password=*** --apply-log --redo-only BASE-DIR
innobackupex --defaults-file=/opt/mysql/my.cnf --user=root --password=*** --apply-log --redo-only BASE-DIR --incremental-dir=INCREMENTAL-DIR-1
innobackupex --defaults-file=/opt/mysql/my.cnf --user=root --password=*** --apply-log BASE-DIR --incremental-dir=INCREMENTAL-DIR-2
其中BASE-DIR是指全备目录,INCREMENTAL-DIR-1是指第一次的增量备份,INCREMENTAL-DIR-2是指第二次的增量备份,以此类推。这里要注意的是:最后一步的增量备份并没有--redo-only选项!还有,可以使用--use_memory提高性能。
以上语句执行成功之后,最终数据在BASE-DIR(即全备目录)下。
我的具体操作:
[root@L112 full]# innobackupex --apply-log --redo-only /backup/mysqldump/full/back_26-05-2017
[root@L112 full]# innobackupex --apply-log --redo-only /backup/mysqldump/full/back_26-05-2017/--incremental-dir=/backup/mysqldump/incremental/back_26-05-2017/
[root@L112 full]# innobackupex --apply-log /backup/mysqldump/full/back_26-05-2017/ --incremental-dir=/backup/mysqldump/incremental/back_27-05-2017/
第二步:回滚未完成的日志,也就是已经刷新到磁盘的,但是还没有提交的。
innobackupex --apply-log BASE-DIR
我的具体操作:
[root@L112 full]# innobackupex --apply-log /backup/mysqldump/full/back_26-05-2017/
上面执行完之后,BASE-DIR里的备份文件已完全准备就绪,
最后一步:是拷贝,这个步骤需要注意先把数据库关掉,并且把数据文件和日志文件删除:
innobackupex --copy-back BASE-DIR
我的具体操作是:
1)关闭mysql服务,并且记录下数据文件目录下的相关目录和文件的权限
[root@L112 data]# service mysql stop
[root@L112 data]# ll
total 28748
-rw-rw----. 1 mysql mysql 18874368 May 27 17:15 ibdata1
-rw-rw----. 1 mysql mysql 5242880 May 27 17:15 ib_logfile0
-rw-rw----. 1 mysql mysql 5242880 May 17 17:20 ib_logfile1
-rw-r-----. 1 mysql root 65782 May 27 17:15 L112.err
drwx------. 2 mysql root 4096 May 17 17:12 mysql
drwx------. 2 mysql mysql 4096 May 17 17:12 performance_schema
drwx------. 2 mysql root 6 May 17 17:12 test
2)删除mysql数据文件目录下的所有东西
[root@L112 data]# rm -rf *
3)执行恢复操作,
[root@L112 full]# innobackupex --copy-back /backup/mysqldump/full/back_26-05-2017/
其中
--copy-back代表拷贝回去,这样原来的备份文件依旧存在
--move-back代表移动回去,这样原来的备份文件就没有了,可以节约空间
4)最重要的一步骤,需要修改目录权限,参照之前记录的。
[root@L112 data]# chown -R mysql:root mysql/
[root@L112 data]# chown -R mysql:root liuwenhe/
[root@L112 data]# chown -R mysql:root test/
[root@L112 data]# chown mysql:mysql ibdata1
[root@L112 data]# chown mysql:mysql ibdata0
[root@L112 data]# chown mysql:mysql ib_logfile1
5)启动数据库:
[root@L112 data]# /etc/init.d/mysqld start
至此恢复过程已经完成,
至于只有全备的恢复相对来说是简单的:就两步骤,
1.apply-log应用日志,保证一致性,
2.copy-back ,恢复。
具体如下:
innobackupex --defaults-file=/opt/mysql/my.cnf --user=root --password=*** --use-memory=4G --apply-log /backup/mysql/data/2013-10-29_09-05-25
innobackupex --defaults-file=/opt/mysql/my.cnf --user=root --password=*** --copy-back /backup/mysql/data/2013-10-29_09-05-25
从什么可以看出,恢复分为两个步骤,第1步是apply-log,为了加快速度,一般建议设置--use-memory,这个步骤完成之后,目录/backup/mysql/data/2013-10-29_09-05-25下的备份文件已经准备就绪。
第2步是copy-back,即把备份文件拷贝至原数据目录下。
恢复完成之后,一定要记得检查数据目录的所有者和权限是否正确。
到此,关于"mysql怎么增量备份和恢复数据"的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注网站,小编会继续努力为大家带来更多实用的文章!