mysql binlog 闪回_MySQL误操作之快速闪回binlog2sql

2023-10-28 16:59

本文主要是介绍mysql binlog 闪回_MySQL误操作之快速闪回binlog2sql,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

项目作者:danfengcao

项目地址:https://github.com/danfengcao/binlog2sql

1、环境限制

mysql server必须开启,离线模式下不能解析binlog

binlog格式必须是行模式

软件版本:Python 2.7 MySQL 5.6

MySQL设置一下参数:

[mysqld]

server-id = 1

log_bin = /var/log/mysql/mysql-bin.log

max_binlog_size = 1000M

binlog-format = row

2、构建数据

建库

root@localhost [mysql]>create databasetest;

Query OK, 1 row affected (0.10 sec)

建表

root@localhost [mysql]>create tabletest01( id int(4) not null auto_increment, name varchar(3), age int(4),primarykey(id))engine=innodb charset=utf8;

Query OK, 0 rows affected (0.13 sec)

插入测试数据

insert into test01(id,name,age)values(1,'tom',25);

insert into test01(id,name,age) values(2,'小丫',23);

insert into test01(id,name,age) values(3,'飞飞',28);

insert into test01(id,name,age) values(4,'参参',16);

insert into test01(id,name,age) values(5,'顺子',330);

insert into test01(id,name,age) values(6,'炸弹',48);

检查测试数据

root@localhost [mysql]>select * fromtest01;

+----+--------+------+

| id | name  | age  |

+----+--------+------+

|  1 |tom    |  25 |

|  2 | 小丫   |   23|

|  3 | 飞飞   |   28|

|  4 | 参参   |   16|

|  5 | 顺子   |  330|

|  6 | 炸弹   |   48|

+----+--------+------+

6 rows in set (0.00 sec)

3、安装binlog2sql

git clone https://github.com/danfengcao/binlog2sql.git

pip install -r requirements.txt

4、模拟删除数据恢复

删除数据

root@localhost [test]>select * fromtest01;

+----+--------+------+

| id | name  | age  |

+----+--------+------+

|  1 |tom    |  25 |

|  2 | 小丫   |   23|

|  3 | 飞飞   |   28|

|  4 | 参参   |   16|

|  5 | 顺子   |  330|

|  6 | 炸弹   |   48|

+----+--------+------+

6 rows in set (0.14 sec)

root@localhost [test]>delete from test01;

Query OK, 6 rows affected (0.09 sec)

root@localhost [test]>select * fromtest01;

Empty set (0.00 sec)

登陆MySQL,查看目前的binlog文件

root@localhost [test]>show master logs;

+------------------+-----------+

| Log_name         | File_size |

+------------------+-----------+

| mysql-bin.000001 |     65396 |

| mysql-bin.000002 |   1179102 |

| mysql-bin.000003 |      3401 |

+------------------+-----------+

3 rows in set (0.03 sec)

最新的binlog文件是mysql-bin.000002,我们再定位误操作SQL的binlog位置

[root@bogon ~]# pythonbinlog2sql/binlog2sql/binlog2sql.py -h127.0.0.1 -P3306 -dtest -ttest01--start-file='mysql-bin.000004'

INSERT INTO `test`.`test01`(`age`, `id`,`name`) VALUES (25, 1, 'tom'); #start 239 end 412

INSERT INTO `test`.`test01`(`age`, `id`,`name`) VALUES (23, 2, '小丫'); #start491 end 667

INSERT INTO `test`.`test01`(`age`, `id`,`name`) VALUES (28, 3, '飞飞'); #start746 end 922

INSERT INTO `test`.`test01`(`age`, `id`,`name`) VALUES (16, 4, '参参'); #start1001 end 1177

INSERT INTO `test`.`test01`(`age`, `id`,`name`) VALUES (330, 5, '顺子'); #start1256 end 1432

INSERT INTO `test`.`test01`(`age`, `id`,`name`) VALUES (48, 6, '炸弹'); #start1511 end 1687

DELETE FROM `test`.`test01` WHERE `age`=25AND `id`=1 AND `name`='tom' LIMIT 1; #start 1766 end 2019

DELETE FROM `test`.`test01` WHERE `age`=23AND `id`=2 AND `name`='小丫' LIMIT 1;#start 1766 end 2019

DELETE FROM `test`.`test01` WHERE `age`=28AND `id`=3 AND `name`='飞飞' LIMIT 1;#start 1766 end 2019

DELETE FROM `test`.`test01` WHERE `age`=16AND `id`=4 AND `name`='参参' LIMIT 1;#start 1766 end 2019

DELETE FROM `test`.`test01` WHERE `age`=330AND `id`=5 AND `name`='顺子' LIMIT 1;#start 1766 end 2019

DELETE FROM `test`.`test01` WHERE `age`=48AND `id`=6 AND `name`='炸弹' LIMIT 1;#start 1766 end 2019

生成回滚sql,并检查回滚sql是否正确

[root@bogon ~]# pythonbinlog2sql/binlog2sql/binlog2sql.py -h127.0.0.1 -P3306 -dtest -ttest01--start-file='mysql-bin.000004' --start-pos=1766 --end-pos=2019 -B

INSERT INTO `test`.`test01`(`age`, `id`,`name`) VALUES (48, 6, '炸弹'); #start1766 end 2019

INSERT INTO `test`.`test01`(`age`, `id`,`name`) VALUES (330, 5, '顺子'); #start1766 end 2019

INSERT INTO `test`.`test01`(`age`, `id`,`name`) VALUES (16, 4, '参参'); #start1766 end 2019

INSERT INTO `test`.`test01`(`age`, `id`,`name`) VALUES (28, 3, '飞飞'); #start1766 end 2019

INSERT INTO `test`.`test01`(`age`, `id`,`name`) VALUES (23, 2, '小丫'); #start1766 end 2019

INSERT INTO `test`.`test01`(`age`, `id`,`name`) VALUES (25, 1, 'tom'); #start 1766 end 2019

确认回滚sql正确,执行回滚语句。

[root@bogon ~]# pythonbinlog2sql/binlog2sql/binlog2sql.py -h127.0.0.1 -P3306 -dtest -ttest01--start-file='mysql-bin.000004' --start-pos=1766 --end-pos=2019 -B | mysql-h127.0.0.1 -P3306

登录mysql,数据回滚成功

root@localhost [test]>select * fromtest01;

+----+--------+------+

| id | name  | age  |

+----+--------+------+

|  1 |tom    |  25 |

|  2 | 小丫   |   23|

|  3 | 飞飞   |   28|

|  4 | 参参   |   16|

|  5 | 顺子   |  330|

|  6 | 炸弹   |   48|

+----+--------+------+

(END)

PS:本软件适用于delete和updete误操作快速闪回,其他功能本人还没有测试过,再次感谢作者的开源。

为了方便大家交流,本人开通了微信公众号和QQ群,QQ群:291519319,喜欢技术的一起来交流吧

8ee405e99bbacaa385ff4ef0a5942c3d.png

这篇关于mysql binlog 闪回_MySQL误操作之快速闪回binlog2sql的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:https://blog.csdn.net/weixin_36323601/article/details/113589963
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/294644

相关文章

Python+PyQt5实现MySQL数据库备份神器

《Python+PyQt5实现MySQL数据库备份神器》在数据库管理工作中,定期备份是确保数据安全的重要措施,本文将介绍如何使用Python+PyQt5开发一个高颜值,多功能的MySQL数据库备份工具... 目录概述功能特性核心功能矩阵特色功能界面展示主界面设计动态效果演示使用教程环境准备操作流程代码深度解

如何清理MySQL中的binlog问题

《如何清理MySQL中的binlog问题》:本文主要介绍清理MySQL中的binlog问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目http://www.chinasem.cn录清理mysql中的binlog1.查看binlog过期时间2. 修改binlog过期

MySQL基本查询示例总结

《MySQL基本查询示例总结》:本文主要介绍MySQL基本查询示例总结,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录Create插入替换Retrieve(读取)select(确定列)where条件(确定行)null查询order by语句li

查看MySql主从同步的偏移量方式

《查看MySql主从同步的偏移量方式》:本文主要介绍查看MySql主从同步的偏移量方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 1.mysql的主从同步方案mysqlphp为了在实现读写分离,主库写,从库读mysql的同步方案主要是通过从库读取主库的binl

MySQL表空间结构详解表空间到段页操作

《MySQL表空间结构详解表空间到段页操作》在MySQL架构和存储引擎专题中介绍了使用不同存储引擎创建表时生成的表空间数据文件,在本章节主要介绍使用InnoDB存储引擎创建表时生成的表空间数据文件,对... 目录️‍一、什么是表空间结构1.1 表空间与表空间文件的关系是什么?️‍二、用户数据在表空间中是怎么

MybatisX快速生成增删改查的方法示例

《MybatisX快速生成增删改查的方法示例》MybatisX是基于IDEA的MyBatis/MyBatis-Plus开发插件,本文主要介绍了MybatisX快速生成增删改查的方法示例,文中通过示例代... 目录1 安装2 基本功能2.1 XML跳转2.2 代码生成2.2.1 生成.xml中的sql语句头2

Java JSQLParser解析SQL的使用指南

《JavaJSQLParser解析SQL的使用指南》JSQLParser是一个Java语言的SQL语句解析工具,可以将SQL语句解析成为Java类的层次结构,还支持改写SQL,下面我们就来看看它的具... 目录一、引言二、jsQLParser常见类2.1 Class Diagram2.2 Statement

mysql中的group by高级用法详解

《mysql中的groupby高级用法详解》MySQL中的GROUPBY是数据聚合分析的核心功能,主要用于将结果集按指定列分组,并结合聚合函数进行统计计算,本文给大家介绍mysql中的groupby... 目录一、基本语法与核心功能二、基础用法示例1. 单列分组统计2. 多列组合分组3. 与WHERE结合使

MySQL数据库实现批量表分区完整示例

《MySQL数据库实现批量表分区完整示例》通俗地讲表分区是将一大表,根据条件分割成若干个小表,:本文主要介绍MySQL数据库实现批量表分区的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参考... 目录一、表分区条件二、常规表和分区表的区别三、表分区的创建四、将既有表转换分区表脚本五、批量转换表为分区

宝塔安装的MySQL无法连接的情况及解决方案

《宝塔安装的MySQL无法连接的情况及解决方案》宝塔面板是一款流行的服务器管理工具,其中集成的MySQL数据库有时会出现连接问题,本文详细介绍两种最常见的MySQL连接错误:“1130-Hostisn... 目录一、错误 1130:Host ‘xxx.xxx.xxx.xxx’ is not allowed