mysql怎么增量备份和恢复数据

100次阅读
没有评论

共计 4740 个字符,预计需要花费 12 分钟才能阅读完成。

这篇文章主要介绍“mysql 怎么增量备份和恢复数据”,在日常操作中,相信很多人在 mysql 怎么增量备份和恢复数据问题上存在疑惑,丸趣 TV 小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”mysql 怎么增量备份和恢复数据”的疑惑有所帮助!接下来,请跟着丸趣 TV 小编一起来学习吧!

全备:

[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 怎么增量备份和恢复数据”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注丸趣 TV 网站,丸趣 TV 小编会继续努力为大家带来更多实用的文章!

正文完
 
丸趣
版权声明:本站原创文章,由 丸趣 2023-08-01发表,共计4740字。
转载说明:除特殊说明外本站除技术相关以外文章皆由网络搜集发布,转载请注明出处。
评论(没有评论)