MySQL使用MyFlash快速恢复误删除和修改的数据

 更新时间:2024年06月16日 10:26:05   作者:小毕超  
MyFlash 是由美团点评公司技术工程部开发并维护的一个开源工具,主要用于MySQL数据库的DML操作的回滚,MyFlash的优势在于它提供了更多的过滤选项,使得回滚操作变得更加容易,本文将实验通过 MyFlash 工具快速恢复误删除 或 误修改的数据,需要的朋友可以参考下

一、MyFlash

MyFlash 是由美团点评公司技术工程部开发并维护的一个开源工具,主要用于MySQL数据库的DML操作的回滚。这个工具通过解析binlog日志,帮助用户高效、方便地进行数据恢复。MyFlash的优势在于它提供了更多的过滤选项,使得回滚操作变得更加容易。与其他数据恢复工具相比,MyFlash无需将binlog解析成文本再进行转换,而是提供了基于库、表、SQL类型、位置、时间等多种过滤方式。

GitHub 地址如下:

https://github.com/Meituan-Dianping/MyFlash

本文将实验通过 MyFlash 工具快速恢复误删除 或 误修改的数据。

注意:要使用 MyFlash ,前提需要将 MySQLbinlog格式改为row,且 binlog_row_image=full,所以在下面实验前,请确保 MySQL 开启了 binlog ,并且 binlog 的格式正确:

show variables like 'log_bin';

在这里插入图片描述

SHOW VARIABLES LIKE 'binlog_row_image';

在这里插入图片描述

二、MyFlash 部署

安装依赖环境:

yum install gcc glib2-devel -y

下载 MyFlash 项目:

wget https://github.com/Meituan-Dianping/MyFlash/archive/master.zip

解压:

unzip master.zip

编译源文件:

cd MyFlash-master
gcc -w `pkg-config --cflags --libs glib-2.0` source/binlogParseGlib.c -o binary/flashback

查看 flashback 命令:

./binary/flashback -h

在这里插入图片描述

解释如下:

  • databaseNames:指定需要回滚的数据库名。多个数据库可以用 , 隔开。如果不指定该参数,相当于指定了所有数据库。
  • tableNames:指定需要回滚的表名。多个表可以用 , 隔开。如果不指定该参数,相当于指定了所有表。
  • start-position:指定回滚开始的位置。如不指定,从文件的开始处回滚。请指定正确的有效的位置,否则无法回滚。
  • stop-position:指定回滚结束的位置。如不指定,回滚到文件结尾。请指定正确的有效的位置,否则无法回滚。
  • start-datetime:指定回滚的开始时间。注意格式必须是 %Y-%m-%d %H:%M:%S。如不指定,则不限定时间。
  • stop-datetime:指定回滚的结束时间。注意格式必须是 %Y-%m-%d %H:%M:%S。如不指定,则不限定时间。
  • sqlTypes:指定需要回滚的 sql 类型。目前支持的过滤类型是 INSERT, UPDATE, DELETE。多个类型可以用 , 隔开。
  • maxSplitSize:指定解析分割后文件最大大小,单位为 M
  • binlogFileNames:指定需要回滚的 binlog 文件,如有多个,用 , 隔开。
  • outBinlogFileNameBase:指定输出的 binlog 文件前缀,如不指定,则默认为 binlog_output_base.flashback
  • logLevel:指定输出的日志级别,可选级别有 debug, warning, error,默认级别为 error 级别。
  • include-gtids:指定需要回滚的 gtid,支持 gtid 的单个和范围两种形式,如有多种形式,用 , 隔开。
  • exclude-gtids:指定不需要回滚的 gtid,支持 gtid 的单个和范围两种形式,如有多种形式,用 , 隔开。

三、测试环境构建

创建测试库:

create database testdb;
use testdb;

创建测试表:

CREATE TABLE `user` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `name` varchar(255) DEFAULT NULL,
  `age` int(11) DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;

写入测试数据:

INSERT INTO `testdb`.`user` (`id`, `name`, `age`) VALUES (1, '张三', 16);
INSERT INTO `testdb`.`user` (`id`, `name`, `age`) VALUES (2, '赵六', 17);
INSERT INTO `testdb`.`user` (`id`, `name`, `age`) VALUES (3, '李四', 18);
INSERT INTO `testdb`.`user` (`id`, `name`, `age`) VALUES (4, '小明', 19);
INSERT INTO `testdb`.`user` (`id`, `name`, `age`) VALUES (5, '小李', 20);

四、数据误删除恢复

假设不小心删除了 age > 17 的数据:

delete from user where age > 17;

在这里插入图片描述

查看当前 binlog 名称:

show master status;

在这里插入图片描述

先生成一个新的 binlog 文件,让后面的操作记录在新的 binlog 文件中:

flush logs;

在这里插入图片描述

使用 MyFlash 反向解析刚才的 mysql-bin.000004 文件,这个可以根据时间范围定位,sqlTypesDELETE 类型:

./binary/flashback --databaseNames="testdb" --tableNames="user" --start-datetime="2024-06-15 14:35:30" --stop-datetime="2024-06-15 14:41:30" --sqlTypes="DELETE" --binlogFileNames=/var/lib/mysql/mysql-bin.000004 --outBinlogFileNameBase=user.sql

在这里插入图片描述

执行后可以看到生成了一个 user.sql.flashback 回滚文件,可以使用 mysqlbinlog 进行查看:

mysqlbinlog -vv user.sql.flashback 

在这里插入图片描述

可以看出内容是 INSERT 操作,用来恢复之前误删除的数据,下面可以直接使用 mysqlbinlog 去执行其中的内容:

mysqlbinlog user.sql.flashback | mysql -uroot -proot

在这里插入图片描述

下面查看数据是否被恢复:

在这里插入图片描述

数据成功恢复!

五、数据误修改恢复

假设修改数据时忘了加 where 条件,导致所有数据都被误修改:

update user set age = 99;

在这里插入图片描述

下面做法和上面相似,首先查看当前 binlog 名称:

show master status;

在这里插入图片描述

同样生成一个新的 binlog 文件,让后面的操作记录在新的 binlog 文件中:

flush logs;

在这里插入图片描述

使用 MyFlash 反向解析刚才的 mysql-bin.000005 文件,这个还是根据时间范围定位,sqlTypes 要改为 UPDATE 类型:

./binary/flashback --databaseNames="testdb" --tableNames="user" --start-datetime="2024-06-15 14:45:30" --stop-datetime="2024-06-15 14:50:30" --sqlTypes="UPDATE" --binlogFileNames=/var/lib/mysql/mysql-bin.000005 --outBinlogFileNameBase=user1.sql

在这里插入图片描述

执行后可以看到生成了一个 user1.sql.flashback 回滚文件,使用 mysqlbinlog 进行查看:

mysqlbinlog -vv user1.sql.flashback 

在这里插入图片描述

可以看出是 UPDATE 操作,用来恢复之前误修改的数据,同样直接使用 mysqlbinlog 去执行其中的内容:

mysqlbinlog user1.sql.flashback | mysql -uroot -proot

在这里插入图片描述

下面查看数据是否恢复:

在这里插入图片描述

数据成功恢复!

以上就是MySQL使用MyFlash快速恢复误删除和修改的数据的详细内容,更多关于MySQL MyFlash恢复误删除数据的资料请关注脚本之家其它相关文章!

相关文章

  • navicat连接mysql报错10060的解决办法

    navicat连接mysql报错10060的解决办法

    最近在学习中遇到了个小问题,现在将解决的办法分享给同样遇到这个问题的同学,这篇文章主要给大家介绍了关于navicat连接mysql报错10060的解决办法,需要的朋友可以参考下
    2023-03-03
  • 一次MySql重置root密码无效的实战记录

    一次MySql重置root密码无效的实战记录

    最近碰见过几次mysql root密码修改无效的情况,在此做一下总,下面这篇文章主要给大家介绍了一次MySql重置root密码无效的实战记录,文中通过示例代码介绍的非常详细,需要的朋友可以参考下
    2022-04-04
  • MySQL 线上日志库迁移实例

    MySQL 线上日志库迁移实例

    这篇文章主要介绍了MySQL 线上日志库迁移实例,帮助大家更好的理解和学习使用MySQL,感兴趣的朋友可以了解下
    2021-03-03
  • 详解MySQL的sql_mode查询与设置

    详解MySQL的sql_mode查询与设置

    这篇文章主要介绍了详解MySQL的sql_mode查询与设置,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-12-12
  • Windows下mysql5.7.10安装配置方法图文教程

    Windows下mysql5.7.10安装配置方法图文教程

    这篇文章主要为大家详细介绍了Windows上mysql5.7.10安装配置方法图文教程,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-04-04
  • 详解MySQL事务的隔离级别与MVCC

    详解MySQL事务的隔离级别与MVCC

    这篇文章主要介绍了MySQL事务的隔离级别与MVCC的相关资料,帮助大家更好的理解和学习使用MySQL,感兴趣的朋友可以了解下
    2021-04-04
  • Mysql使用sum()函数返回null的问题详解

    Mysql使用sum()函数返回null的问题详解

    MySQL的Sum()函数是用来找出所有记录的一个字段的总和,下面这篇文章主要给大家介绍了关于Mysql使用sum()函数返回null的问题,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
    2022-01-01
  • SQL语句中OR和AND的混合使用的小技巧

    SQL语句中OR和AND的混合使用的小技巧

    在SQL语句中我们可能会经常混合使用到OR和AND,其中可能会出现一些小问题,下面小编来讲一讲它的使用技巧
    2019-05-05
  • 深入解析mysql.sock不见的问题

    深入解析mysql.sock不见的问题

    本篇文章是对mysql.sock不见的问题进行了详细的分析介绍,需要的朋友参考下
    2013-06-06
  • 深入了解MySQL ClickHouse中的物化视图功能

    深入了解MySQL ClickHouse中的物化视图功能

    MapReduce是一种用于处理大规模数据集的并行编程模型,其特点高效性和可扩展性,这篇文章主要介绍了MySQL ClickHouse中的物化视图功能,需要详细了解可以参考下文
    2023-05-05

最新评论