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 系统。
1
rubygo 356 天前
是否有不需要连接库的。
|
2
hcymysql OP 这个必须连接数据库获取 binlog
|
3
leorealman 351 天前
mysql5.5 、5.6 支持嘛?
|