MySQL不同于oracle,没有闪回查询这类概念,但网上流传几个闪回的开源工具如 binglog2sql、MyFlash,可以使用binglog日志进行误操作数据的恢复。
笔者以前测试过 binglog2sql,发现安装配置比较复杂不太友好。
本次测试了下 MyFlash 这个开源工具,发现相对简单易用,特此做一个使用记录。
MyFlash是由美团点评公司技术工程部开发维护的一个回滚DML操作的工具。该工具通过解析v4版本的binlog,完成回滚操作。相对已有的回滚工具,其增加了更多的过滤选项,让回滚更加容易。
■ MyFlash 安装
下载:
wget https://github.com/Meituan-Dianping/MyFlash/archive/refs/heads/master.zip
解压缩、动态编译链接:
unzip master.zip && cd MyFlash-master
gcc -w `pkg-config --cflags --libs glib-2.0` source/binlogParseGlib.c -o binary/flashback
如编译时遇到复杂难解问题,可以换机器编译操作!
■ 执行闪回操作
默认会将闪回结果存放到 binlog_output_base.flashback
./flashback --databaseNames=dbname --tableNames=tblname --sqlTypes='DELETE' --start-datetime="2022-10-27 16:54:00" --stop-datetime="2022-10-27 18:27:00" --binlogFileNames=binlog.000288
■ 确认是否想要的恢复操作
mysqlbinlog --no-defaults --base64-output=decode-rows -vv binlog_output_base.flashback | grep "INSERT" | wc -l
可见有大约 9864 个 insert 操作,对应误删时段的 delete 操作
■ 应用闪回日志恢复误删
mysqlbinlog binlog_output_base.flashback | mysql -u'root' -p'passwd'