MySQL 误操作闪回工具 - reverse_sql

172 天前
 hcymysql

reverse_sql 是一个用于解析和转换 MySQL 二进制日志( binlog )的工具。它可以将二进制日志文件中记录的数据库更改操作(如插入、更新、删除)转换为反向的 SQL 语句,以便进行数据恢复。其运行模式需二进制日志设置为 ROW 格式。

https://github.com/hcymysql/reverse_sql

该工具的主要功能和特点包括:

1 、解析二进制日志:reverse_sql 能够解析 MySQL 的二进制日志文件,并还原出其中的 SQL 语句。

2 、生成可读的 SQL:生成原始 SQL 和反向 SQL 。

3 、支持过滤和筛选:可以根据时间范围、表、DML 操作等条件来过滤出具体的误操作 SQL 语句。

4 、支持多线程并发解析 binlog 事件。

请注意! reverse_sql 只是将二进制日志还原为 SQL 语句,而不会执行这些 SQL 语句来修改数据库。

使用

shell> chmod 755 reverse_sql

Example usage:

shell> ./reverse_sql -ot table1 -op delete -H 192.168.198.239 -P 3336 -u admin -p hechunyang -d hcy --binlog-file mysql-bin.000124 --start-time "2023-07-06 10:00:00" --end-time "2023-07-06 22:00:00" 
        

当出现误操作时,只需指定误操作的时间段,其对应的 binlog 文件(通常你可以通过 show master status 得到当前的 binlog 文件名)以及刚才误操作的表,和具体的 DML 命令,比如 update 或者 delete 。

工具运行后,会在当前目录下生成一个{db}_{table}_recover.sql 文件,保存着原生 SQL (原生 SQL 会加注释) 和 反向 SQL ,如果想将结果输出到前台终端,可以指定--print 选项。

如果你想把 update 操作转换为 replace ,指定--replace 选项即可,同时会在当前目录下生成一个{db}_{table}_recover_replace.sql 文件。

不支持 drop 和 truncate 操作,因为这两个操作属于物理性删除,需要通过历史备份进行恢复。

注:reverse_sql 支持 MySQL 5.7/8.0 和 MariaDB ,适用于 CentOS 7 系统。

767 次点击
所在节点    MySQL
3 条回复
rubygo
171 天前
是否有不需要连接库的。
hcymysql
171 天前
这个必须连接数据库获取 binlog
leorealman
166 天前
mysql5.5 、5.6 支持嘛?

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/994592

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX