欢迎来到阿里云授权服务中心典名科技有限公司!咨询电话:023-66887777 18623333330

微信
手机版
网站地图

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

2021-08-18 09:38:13 投稿人 : admin 围观 : 159 次 0 评论

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

image.png


全备:

[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,即把备份文件拷贝至原数据目录下。

恢复完成之后,一定要记得检查数据目录的所有者和权限是否正确。

版权声明:本站部分文章内容、图片来源于网友推荐、互联网收集整理而来,仅供大家学习参考,不代表本站立场,如有侵权,请联系站长,我们会第一时间处理!本站原创内容未经允许不得转载,或转载时需注明出处:典名科技资讯门户

相关文章

  • oracle临时表空间的增删改查命令
    oracle临时表空间的增删改查命令

    oracle临时表空间的增删改查命令发布时间:2021-08-31 01:57:42来源:阿里云阅读:60作者:chen栏目:关系型数据库本篇内容介绍了“oracle临时表空间的增删改查命令”的有关知识,在实际案例的操作过程中,不少人都会遇...

    2021-08-31 11:52:19
  • Redis4.0从库复制报错"master_link_status:down"怎么处理
    Redis4.0从库复制报错"master_link_status:down"怎么处理

    “Redis4.0从库复制报错"master_link_status:down"怎么处理”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Redis4.0从库复制报错&quo...

    2021-08-31 11:52:19
  • MySQL数据库中有哪些锁
    MySQL数据库中有哪些锁

    “MySQL数据库中有哪些锁”,在日常操作中,相信很多人在MySQL数据库中有哪些锁问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”MySQL数据库中有哪些锁”的疑惑有所帮助!接下来!在 MySQL 数据库中,...

    2021-08-31 11:24:19
  • MSSQL报错参数数据类型text对于replace函数的参数1无效怎么解决
    MSSQL报错参数数据类型text对于replace函数的参数1无效怎么解决

    “MSSQL报错参数数据类型text对于replace函数的参数1无效怎么解决”,在日常操作中,相信很多人在MSSQL报错参数数据类型text对于replace函数的参数1无效怎么解决问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作...

    2021-08-31 11:21:19
  • solaris11 ssh怎么禁止root用户连接
    solaris11 ssh怎么禁止root用户连接

    “solaris11 ssh怎么禁止root用户连接”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“solaris11 ssh怎么禁止root用户连接”吧!在虚拟机中新安装的solaris11,安...

    2021-08-31 11:20:19
  • 怎么用SQL语句查看SQL Server的结构信息
    怎么用SQL语句查看SQL Server的结构信息

    “怎么用SQL语句查看SQL Server的结构信息”,在日常操作中,相信很多人在怎么用SQL语句查看SQL Server的结构信息问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”怎么用SQL语句查看SQL S...

    2021-08-31 11:04:20
  • sqlplus和sqlldr工具的安装方法
    sqlplus和sqlldr工具的安装方法

    “sqlplus和sqlldr工具的安装方法”。本文介绍的方法操作简单快捷,实用性强。sqlplus和sqlldr工具的安装方法”吧!不管安装什么客户端工具都需要先安装instantclient-basic-linux.x64-11.2.0...

    2021-08-31 10:59:20
  • MHA的安装和部署步骤
    MHA的安装和部署步骤

    “MHA的安装和部署步骤”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!##################MHA安装和部署###########...

    2021-08-31 10:52:20
  • redis4.0下MEMORY命令详解
    redis4.0下MEMORY命令详解

    “redis4.0下MEMORY命令详解”,在日常操作中,相信很多人在redis4.0下MEMORY命令详解问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”redis4.0下MEMORY命令详解”的疑惑有所帮助...

    2021-08-31 10:52:19
  • MySQL内存线程独享使用的方法
    MySQL内存线程独享使用的方法

    “MySQL内存线程独享使用的方法”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“MySQL内存线程独享使用的方法”吧!  今天这篇文章暂时先分析 MySQL 中主要的 “线程独享内存” 的。...

    2021-08-25 10:37:36
发表评论