一、MyFlash
MyFlash
是由美团点评公司技术工程部开发并维护的一个开源工具,主要用于MySQL
数据库的DML
操作的回滚。这个工具通过解析binlog
日志,帮助用户高效、方便地进行数据恢复。MyFlash
的优势在于它提供了更多的过滤选项,使得回滚操作变得更加容易。与其他数据恢复工具相比,MyFlash
无需将binlog
解析成文本再进行转换,而是提供了基于库、表、SQL
类型、位置、时间等多种过滤方式。
GitHub
地址如下:
本文将实验通过 MyFlash
工具快速恢复误删除 或 误修改的数据。
注意:要使用 MyFlash
,前提需要将 MySQL
的 binlog
格式改为row
,且 binlog_row_image=full
,所以在下面实验前,请确保 MySQL
开启了 binlog
,并且 binlog
的格式正确:
1 | show variables like 'log_bin' ; |
1 | SHOW VARIABLES LIKE 'binlog_row_image' ; |
二、MyFlash 部署
安装依赖环境:
1 | yum install gcc glib2-devel -y |
下载 MyFlash
项目:
1 | wget https: //github .com /Meituan-Dianping/MyFlash/archive/master .zip |
解压:
1 | unzip master.zip |
编译源文件:
1 | cd MyFlash-master |
1 | gcc -w `pkg-config --cflags --libs glib-2.0` source /binlogParseGlib .c -o binary /flashback |
查看 flashback
命令:
1 | . /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
的单个和范围两种形式,如有多种形式,用,
隔开。
三、测试环境构建
创建测试库:
1 | create database testdb; |
1 | use testdb; |
创建测试表:
1 2 3 4 5 6 | 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; |
写入测试数据:
1 2 3 4 5 | 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
的数据:
1 | delete from user where age > 17; |
查看当前 binlog
名称:
1 | show master status; |
先生成一个新的 binlog
文件,让后面的操作记录在新的 binlog
文件中:
1 | flush logs; |
使用 MyFlash
反向解析刚才的 mysql-bin.000004
文件,这个可以根据时间范围定位,sqlTypes
为 DELETE
类型:
1 | . /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
进行查看:
1 | mysqlbinlog -vv user.sql.flashback |
可以看出内容是 INSERT
操作,用来恢复之前误删除的数据,下面可以直接使用 mysqlbinlog
去执行其中的内容:
1 | mysqlbinlog user.sql.flashback | mysql -uroot -proot |
下面查看数据是否被恢复:
数据成功恢复!
五、数据误修改恢复
假设修改数据时忘了加 where
条件,导致所有数据都被误修改:
1 | update user set age = 99; |
下面做法和上面相似,首先查看当前 binlog
名称:
1 | show master status; |
同样生成一个新的 binlog
文件,让后面的操作记录在新的 binlog
文件中:
1 | flush logs; |
使用 MyFlash
反向解析刚才的 mysql-bin.000005
文件,这个还是根据时间范围定位,sqlTypes
要改为 UPDATE
类型:
1 | . /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
进行查看:
1 | mysqlbinlog -vv user1.sql.flashback |
可以看出是 UPDATE
操作,用来恢复之前误修改的数据,同样直接使用 mysqlbinlog
去执行其中的内容:
1 | mysqlbinlog user1.sql.flashback | mysql -uroot -proot |
下面查看数据是否恢复:
数据成功恢复!
以上就是MySQL使用MyFlash快速恢复误删除和修改的数据的详细内容,更多关于MySQL MyFlash恢复误删除数据的资料请关注IT俱乐部其它相关文章!