加入收藏 | 设为首页 | 会员中心 | 我要投稿 拼字网 - 核心网 (https://www.hexinwang.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MySql教程 > 正文

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

发布时间:2022-01-19 19:18:01 所属栏目:MySql教程 来源:互联网
导读:这篇文章主要介绍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
 
我的具体操作:
 
[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 *

(编辑:拼字网 - 核心网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!