广告
返回顶部
首页 > 资讯 > 数据库 >mysql怎么增量备份和恢复数据
  • 707
分享到

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

2024-04-02 19:04:59 707人浏览 八月长安
摘要

这篇文章主要介绍“Mysql怎么增量备份和恢复数据”,在日常操作中,相信很多人在mysql怎么增量备份和恢复数据问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”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怎么增量备份和恢复数据”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注编程网网站,小编会继续努力为大家带来更多实用的文章!

您可能感兴趣的文档:

--结束END--

本文标题: mysql怎么增量备份和恢复数据

本文链接: https://www.lsjlt.com/news/59186.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • mysql怎么增量备份和恢复数据
    这篇文章主要介绍“mysql怎么增量备份和恢复数据”,在日常操作中,相信很多人在mysql怎么增量备份和恢复数据问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”mysql怎么增...
    99+
    2022-10-18
  • MySQL怎么全量、增量备份与恢复数据
    这篇文章主要讲解了“MySQL怎么全量、增量备份与恢复数据”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“MySQL怎么全量、增量备份与恢复数据”吧!数据备份...
    99+
    2022-10-18
  • MySQL数据库全量、增量备份与恢复
    造成数据丢失的原因 程序错误 人为商店 计算机失败 磁盘失败 灾难(如火山、地震)和偷窃 数据库备份的分类 从物理与逻辑的角度,备份可分为: 物理备份:对数据库操作系统的物理文件(如数据文件、日志文...
    99+
    2015-05-05
    MySQL数据库全量 增量备份与恢复
  • xtrabackup全量、增量备份恢复mysql数据库
    一. 全量备份恢复: 查看原表内容: MariaDB [(none)]> select * from testdb.students; +----+------------+------...
    99+
    2022-10-18
  • innobackupex怎么增量备份与恢复数据
    本篇内容主要讲解“innobackupex怎么增量备份与恢复数据”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“innobackupex怎么增量备份与恢复数据”吧...
    99+
    2022-10-18
  • mysql增量备份断点恢复
    生产环境中在mysql中误操作是非常正常的,所以就需要用到mysql的增量备份恢复。增量备份是我们经常用到的,它可以指定某个误操作的时间以及位置点进行数据恢复,更加准确的恢复我们想要还原的数据。以下实验为大...
    99+
    2022-10-18
  • 数据库篇——完全、增量备份和恢复
    一、准备数据库环境 1、搭建安装环境 yum -y install \ gcc \ gcc-c++ \ make \ ncurses \ ncurses-devel \ bison \ Cmake 2、添加...
    99+
    2022-10-18
  • MySQL增量备份与恢复--实验
    1、创建全备 innobackupex --defaults-file=/etc/my.cnf --user=root --password=root --socket=/home/mysql/3306/d...
    99+
    2022-10-18
  • mysql增量备份及断点恢复
    简介增量备份是指在一次全备份或上一次增量备份后,以后每次的备份只需备份与前一次相比增加或者被修改的文件。这就意味着,第一次增量备份的对象是进行全备后所产生的增加和修改的文件;第二次增量备份的对象是进行第一次...
    99+
    2022-10-18
  • mysql增量备份与恢复实战
    备份:mysqldump -uroot -p** -A -B -F --master-data=2 --single-transaction  --events > /root/all.sq...
    99+
    2022-10-18
  • 怎么备份和恢复MySQL数据库
    这篇文章主要介绍“怎么备份和恢复MySQL数据库”,在日常操作中,相信很多人在怎么备份和恢复MySQL数据库问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”怎么备份和恢复MyS...
    99+
    2022-10-18
  • MySQL完全、增量的备份与恢复
    数据库备份的重要性 提高系统的高可用性和灾难可恢复性,在数据库系统崩溃时,没有数据备份就没法找到数据。 使用数据库备份还原数据库,是数据库崩溃时提供数据恢复最小代价的最优方案。 没有数据库就没有一切,数据...
    99+
    2022-10-18
  • MySQL增量备份与恢复的示例
    小编给大家分享一下MySQL增量备份与恢复的示例,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!文章目录一、MySQL 增量备份1...
    99+
    2022-10-18
  • MySQL 数据备份和数据恢复
    目录 一、数据备份 1、概述 2、MySQLdump命令备份 1)备份单个数据库中的所有表 2) 备份数据中某个或多个表 3) 备份所有数据库 4)备份多个库 5) 只备份一个表或多个表结构 二、数据恢复 三、数据备份与恢复应用 一、数...
    99+
    2023-09-01
    mysql 数据库
  • MySQL 数据恢复 全备份恢复以及增量恢复 (以手残删库为例)
    数据恢复原理图测试环境 MySQL5.51 首先新建数据库 lampol  数据表 test create database lampol;use lampol;create table...
    99+
    2022-10-18
  • MySQL数据库如何实现Percona全量增量备份与恢复
    本文主要给大家简单讲讲MySQL数据库如何实现Percona全量增量备份与恢复,相关专业术语大家可以上网查查或者找一些相关书籍补充一下,这里就不涉猎了,我们就直奔主题吧,希望MySQL数据库如何实现Perc...
    99+
    2022-10-18
  • MySQL中怎么备份和恢复数据表
    今天就跟大家聊聊有关MySQL中怎么备份和恢复数据表,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。你可以使用SELECT INTO OUTF...
    99+
    2022-10-18
  • mysql怎么备份与恢复数据
    本篇内容介绍了“mysql怎么备份与恢复数据”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!一、直接物理文件...
    99+
    2022-10-18
  • MySQL数据库备份和恢复
    目录 MySQL数据库备份和恢复 备份恢复概述 为什么要备份 备份注意要点 还原要点 备份类型: 备...
    99+
    2015-03-06
    MySQL数据库备份和恢复
  • XtraBackup MySql 数据备份和恢复
    wget https://www.percona.com/downloads/XtraBackup/Percona-XtraBackup-2.4.12/binary/redhat/6/x86_64/percona-xtrabackup-24...
    99+
    2017-01-22
    XtraBackup MySql 数据备份和恢复
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作