mysql之 innobackupex备份+binlog日志的完全恢复【转】

时间:2023-02-22 09:08:05

前言:
MySQL的完全恢复,我们可以借助于完整的 备份+binlog 来将数据库恢复到故障点。
备份可以是热备与逻辑备份(mysqldump),只要备份与binlog是完整的,都可以实现完全恢复。

1. 准备实验环境

mysql> select version();
+------------+
| version() |
+------------+
| 5.6.-log |
+------------+
row in set (0.00 sec)
mysql> create database com_rec;
Query OK, row affected (0.00 sec)
mysql> use inc_rec;
Database changed
mysql> create table andy (id int);
Query OK, rows affected (0.08 sec)
mysql> insert into andy values(),();
Query OK, rows affected (0.00 sec)
Records: Duplicates: Warnings:

2. 全备

[root@mysql02 full]# innobackupex --defaults-file=/etc/my.cnf --user=root --password=oracle --port= /xtrabackup/full/
xtrabackup: Transaction log of lsn () to () was copied.
:: completed OK!

3. 查看全备生成文件

[root@mysql02 full]# ll /xtrabackup/full/
total
drwxr-x---. root root Jun : --09_17--

4. 模拟业务新数据

mysql> insert into andy values(),();
Query OK, rows affected (0.14 sec)
Records: Duplicates: Warnings:
mysql> commit;
Query OK, rows affected (0.00 sec)

5. 增量备份

-- 创建存放增量备份目录并赋权
[root@mysql02 full]# mkdir -p /xtrabackup/incr/
[root@mysql02 full]# chown -R mysql:mysql /xtrabackup/incr/
[root@mysql02 full]# ll /xtrabackup/
total
drwxr-xr-x. mysql mysql Jun : full
drwxr-xr-x. mysql mysql Jun : incre
-- 正式开始增量备份
[root@mysql02 full]# innobackupex --defaults-file=/etc/my.cnf --user=root --password=oracle --incremental \
--incremental-basedir=/xtrabackup/full/--09_17--/ /xtrabackup/incr/
########################################下面是增量备份输出
。。。省略
xtrabackup: Transaction log of lsn () to () was copied.
:: completed OK!

6. 再模拟新业务,该记录在保存在binlog,而不会存在于任何备份,这条记录用于验证完全恢复

mysql> insert into andy values();
Query OK, row affected (0.00 sec)

7. 记下操作后的 position 点

mysql> show master status;
+---------------+----------+--------------+------------------+-------------------+
| File | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set |
+---------------+----------+--------------+------------------+-------------------+
| binlog. | | | | |
+---------------+----------+--------------+------------------+-------------------+
row in set (0.00 sec)

8. 切换binlog日志

mysql> flush logs;
Query OK, rows affected (0.00 sec)

9. 使用binlog events命令来查看我们最后insert的一条记录

mysql> show binlog events in 'binlog.000005';
+---------------+------+-------------+-----------+-------------+-----------------------------------------------+
| Log_name | Pos | Event_type | Server_id | End_log_pos | Info |
+---------------+------+-------------+-----------+-------------+-----------------------------------------------+
| binlog. | | Format_desc | | | Server ver: 5.6.-log, Binlog ver: |
| binlog. | | Query | | | drop database inc_rec |
| binlog. | | Query | | | create database com_rec |
| binlog. | | Query | | | use `com_rec`; create table andy (id int) |
| binlog. | | Query | | | BEGIN |
| binlog. | | Query | | | use `com_rec`; insert into andy values(),() |
| binlog. | | Xid | | | COMMIT /* xid=67 */ |
| binlog. | | Query | | | BEGIN |
| binlog. | | Query | | | use `com_rec`; insert into andy values(),() |
| binlog. | | Xid | | | COMMIT /* xid=81 */ |
| binlog. | | Query | | | BEGIN |
| binlog. | | Query | | | use `com_rec`; insert into andy values() |
| binlog. | | Xid | | | COMMIT /* xid=96 */ |
| binlog. | | Rotate | | | binlog.;pos= |
+---------------+------+-------------+-----------+-------------+-----------------------------------------------+
rows in set (0.00 sec)

10. 查看binlog的位置 与 datadir 的位置, 防止 mv datadir时误操作 binlog ,影响恢复 (binlog与datadir一定要分开放置)

mysql> show variables like '%log_bin%';
+---------------------------------+------------------------------------+
| Variable_name | Value |
+---------------------------------+------------------------------------+
| log_bin | ON |
| log_bin_basename | /data/mysql/binarylog/binlog |
| sql_log_bin | ON |
+---------------------------------+------------------------------------+
rows in set (0.00 sec) mysql> show variables like '%datadir%';
+---------------+--------------+
| Variable_name | Value |
+---------------+--------------+
| datadir | /data/mysql/ |
+---------------+--------------+
row in set (0.00 sec)

11. 恢复
11.1 先做基于全备的apply,注意,此时使用了--redo-only

[root@mysql02 full]# innobackupex --defaults-file=/etc/my.cnf --user=root --apply-log --redo-only /xtrabackup/full/--09_17--/
:: completed OK!

11.2 在恢复增量备份集: --此时没有--redo-only,如果有多个增备,仅仅最后一个增备无需指定--redo-only

[root@mysql02 full]# innobackupex --defaults-file=/etc/my.cnf --user=root --apply-log /xtrabackup/full/--09_17--/ --incremental-dir=/xtrabackup/incr/--09_17--/
:: completed OK! #结果出现completed OK表示完全成功
说明: /xtrabackup/full/--09_17--/ 为全备基目录 , incremental-dir 为增量备份目录

12. 关闭要恢复的实例

[root@mysql02 data]# /etc/init.d/mysql stop -p3306
netstat -nltp|grep mysql|grep

13.将原有文件夹重命名到新位置,并创建原文件夹

[root@mysql02 full]# mv /data/mysql /data/mysqlbak
[root@mysql02 full]# mkdir -p /data/mysql

14.执行拷贝恢复的文件到原来的数据位置

[root@mysql02 full]# innobackupex --defaults-file=/etc/my.cnf --user=root --copy-back /xtrabackup/full/--09_17--/
:: completed OK! #结果出现completed OK表示完全成功
说明: /xtrabackup/full/--09_17--/ 为全备基目录

15. 权限修改

[root@mysql02 ~]# mkdir -p /data/mysql/binarylog (说明:这里我binlog在datadir在路径下,所以要单独为binlog创建目录)
-- 将binlog日志mv回原位置 (如果binlog不在datadir下,就不用操作)
[root@mysql02 xtrabackup]# ll /data/mysqlbak/binarylog/
total
-rw-rw----. mysql mysql Jun : binlog.
-rw-rw----. mysql mysql Jun : binlog.
-rw-rw----. mysql mysql Jun : binlog.
-rw-rw----. mysql mysql Jun : binlog.
-rw-rw----. mysql mysql Jun : binlog.
-rw-rw----. mysql mysql Jun : binlog.
-rw-rw----. mysql mysql Jun : binlog.index [root@mysql02 data]# mv /data/mysqlbak/binarylog/* /data/mysql/binarylog/
[root@mysql02 xtrabackup]# ll /data/mysql/binarylog/
total 28
-rw-rw----. 1 mysql mysql 164 Jun 9 06:12 binlog.000001
-rw-rw----. 1 mysql mysql 386 Jun 9 06:14 binlog.000002
-rw-rw----. 1 mysql mysql 143 Jun 9 06:53 binlog.000003
-rw-rw----. 1 mysql mysql 143 Jun 9 07:35 binlog.000004
-rw-rw----. 1 mysql mysql 1148 Jun 9 17:45 binlog.000005
-rw-rw----. 1 mysql mysql 143 Jun 9 17:48 binlog.000006
-rw-rw----. 1 mysql mysql 216 Jun 9 17:45 binlog.index [root@mysql02 data]# chown -R mysql:mysql /data/mysql

16. 启动恢复后的实例

mysqld_safe --defaults-file=/etc/my.cnf &

17. 登录检查

[root@mysql02 ~]# mysql -uroot -poracle
mysql> use com_rec
mysql> select * from andy;
+------+
| id |
+------+
| |
| |
| |
| | > 恢复成功,但是没有恢复到最新,缺少 id= , 'Inbinlog'记录并没有被恢复 。
+------+

18. 使用binlog做完全恢复

[root@mysql02 ~]# cd /xtrabackup/incr/--09_17--/
--从innobackupex获得binlog的位置
[root@mysql02 --09_17--]# more xtrabackup_binlog_info
binlog.
--使用mysqlbinlog 追加的最新
[root@mysql02 --09_17--]# mysqlbinlog --start-position= --stop-position= /data/mysql/binarylog/binlog. | mysql -uroot -poracle
补充:
这样做确实可以,而且row模式的binlog,也可以通过这种方式来执行。但是这样做有几个缺点
a. 如果解析出来的binlog在执行的过程中报错,如何处理?直接加 -f 强制执行吗?
b. 执行中途如何停下来,下次接着跑? 比如我想调整一下MySQL的参数(需要重启)后继续跑?
c. 只能单线程执行。而且mysqlbinlog解析再通过管道执行,有比较高的性能开销。

19. 验证,可以看到最后一条记录以及被恢复

mysql> select * from andy;
+------+
| id |
+------+
| |
| |
| |
| |
| |
+------+
rows in set (0.00 sec)

总结
a、对于完全恢复,我们需要使用备份加binlog两者结合的方式来实现
b、在恢复期间,首先使用带read-only的apply-log方式来prepare全备
c、接下来使用带read-only的apply-log方式来prepare增备,仅最后一个增备可以不用read-only
d、停止原有实例,并copy-back后启动恢复后的实例
e、从Innobakcupex备份信息中获取最后的binlog日志及位置信息
f、使用mysqlbinlog方式将日志追加到最新时刻

转自

mysql之 innobackupex备份+binlog日志的完全恢复(命令行执行模式) - CSDN博客 https://blog.csdn.net/zhang123456456/article/details/72954519

参考

mysqldump+binlog的备份与恢复和xtrabackup备份工具-13007865-51CTO博客 http://blog.51cto.com/13017865/2046944

mysql之 innobackupex备份+binlog日志的完全恢复【转】的更多相关文章

  1. mysql之 innobackupex备份+binlog日志的完全恢复(命令行执行模式)

    前言:MySQL的完全恢复,我们可以借助于完整的 备份+binlog 来将数据库恢复到故障点.备份可以是热备与逻辑备份(mysqldump),只要备份与binlog是完整的,都可以实现完全恢复. 1. ...

  2. innobackupex基于binlog日志的恢复 -- 模拟slave恢复

    说明:一般来说,如果恢复的binlog量不大,可以使用此方法来恢复:mysqlbinlog /data/mysqlbak/binlogbak/restoredb-bin.000018 |mysql - ...

  3. innobackupex基于binlog日志的恢复 -- 使用mysqlbinlog恢复

    备份先做一次完整备份: innobackupex --defaults-file=/etc/my.cnf --user root --password chengce243 /data/mysqlba ...

  4. MySQL用户授权 和 bin-log日志 详解和实战(http://www.cnblogs.com/it-cen/p/5234345.html)

    看 了上一篇博文的发布时间,到目前已经有三个月没更新博文了.这三个月经历了很多事情,包括工作.生活和感情等等.由于个人发展的原因,这个月准备换工作 啦.在这段时间,我会把Web大型项目中所接触到的技术 ...

  5. MySQL用户授权 和 bin-log日志 详解和实战

    看了上一篇博文的发布时间,到目前已经有三个月没更新博文了.这三个月经历了很多事情,包括工作.生活和感情等等.由于个人发展的原因,这个月准备换工作啦.在这段时间,我会把Web大型项目中所接触到的技术都总 ...

  6. MySQL按天备份二进制日志

    #!/usr/bin/env python # -*- coding:utf-8 -*- # Author:guozhen.zhang     import MySQLdbimport timeimp ...

  7. 清理300多台MySQL数据库的过期binlog日志

    早晨睡梦中,被 on-call了,说磁盘报警,赶紧起来打开email,收到上百封email报警,数据库磁盘不够了,查询了原因 [xxx@xxxx cacti]$ ssh xxxx "df - ...

  8. MySQL 开启和查看bin-log日志

    1.5.7版本前修改my.cnf文件,添加log-bin=my-bin(my.cnf的位置根据自己安装的路径查看)# vi /usr/local/mysql/my.cnflog-bin=my-bin  ...

  9. 查看MySQL还原出来的binlog日志中内容方法

    用mysqlbinlog查出需要查看的数据后,可以用more来查看: [root@yoon data]# more recover_sakila.sql | grep --ignore-case -E ...

随机推荐

  1. localdomain的linux域

    both和and的区别? both强调(两者)都,用于肯定语气, and字面意思是"和,而且",是用于表示并列关系的句子,通常位于最后两个人或物之间,将将人物串联起来 如: thi ...

  2. CTE计算层级关系

    推广渠道表有ParentID字段,代表上下层级关系.现要统计每个推广员,推广了多少人? --创建表结构,插入测试数据 USE DBA_Monitor GO CREATE TABLE [dbo].[TG ...

  3. 【转】去掉eclipse的validate

    转载地址:http://www.blogjava.net/leisure/archive/2013/01/11/394087.html 困扰了好几天,与大家共享 1,在project名称上右键选择pr ...

  4. 2012年7月12 – 腾讯公司 WEB高级应用开发工程师 最新面试题 [转]

    笔试(45 minute):(本来是四张纸,被我弄丢了一张!无伤大雅,难度级别不会有出入) 注意:由于时间紧迫和水平有限,难免有不足或错误,请指证,虚心学习! [PHP] 写出PHP中至少5个全局变量 ...

  5. IOS UI 笔记整理回顾

    注意手势会冒泡上抛,一个view没有实现的手势,如果父类view有实现,父视图就处理,如果不想让父视图处理,就把本视图添加到底层window上 setMasksToBounds:YES imageVi ...

  6. Spring集成PageHelper的简单用法

    1.Maven依赖,注意使用PageHelper时的版本必须与Mybatis版本对应 <!-- 添加Mybatis依赖 --> <dependency> <groupId ...

  7. java与&period;net平台之间进行RSA加密验证

    RSA加密算法虽然不分平台,标准都是一样的,但是各个平台的实现方式都不尽相同,下面来我来说说java与.net平台之间该如何进行RSA加密验证,即java端加密->.net端验证和.net端加密 ...

  8. HDU 3966 dfs序&plus;LCA&plus;树状数组

    题目意思很明白: 给你一棵有n个节点的树,对树有下列操作: I c1 c2 k 意思是把从c1节点到c2节点路径上的点权值加上k D c1 c2 k 意思是把从c1节点到c2节点路径上的点权值减去k ...

  9. phpDocumentor2安装配置和使用

    今天弄了下 phpDocumentor2生成项目文档,感觉效果还是不错的 不过因为已经安装过了,之前没有截图,现在没法办重新截图了,下次补上 官网地址 http://phpdoc.org 一.安装: ...

  10. ios jenkins从0快速配置

    1,安装:brew install jenkins2,命令行里:jenkins 回车,第一次会生成密码和保存密码的路径如:/Users/uname/.jenkins/secrets/initialAd ...