reverse_sql binlog解析工具 binlog 解析成 sql
haoteby 2024-11-10 10:30 9 浏览
工具介绍:
reverse_sql是一个用于解析和转换MySQL二进制日志(binlog)的工具。它可以将二进制日志文件中记录的数据库更改操作(如插入、更新、删除)转换为反向的SQL语句,以便进行数据恢复。其运行模式需二进制日志设置为ROW格式。
关于reverse_sql,主要功能和特点如下:
1、它能够解析MySQL的二进制日志文件,并还原出其中的SQL语句,实现二进制日志的解析。
2、它可以生成原始SQL和反向SQL两种可读的SQL语句。
3、它支持根据时间范围、表、DML操作等条件来过滤出具体的误操作SQL语句,实现过滤和筛选功能。
4、它支持多线程并发解析binlog事件,可以提高解析效率。
需要注意的是,reverse_sql只是将二进制日志还原为SQL语句,而不会执行这些SQL语句来修改数据库。
关于reverse_sql的原理如下:
它调用了官方的python-mysql-replication库来实现,通过指定的时间范围,转换为timestamp时间戳,然后将整个时间范围平均分配给每个线程。
因为BinLogStreamReader并不支持指定时间戳来进行递增解析,所以在每个任务开始之前,使用上一个任务处理过的binlog_file和binlog_pos,这样后续的线程就可以获取到上一个线程处理过的binlog文件名和position,然后进行后续的并发处理。
假设开始时间戳start_timestamp是1625558400,线程数量num_threads是4,那么整个时间范围会被平均分配给每个线程。对于第一个线程(i=0),start_time是1625558400。对于第二个线程(i=1),start_time是1625558400 + time_range。依此类推,最后一个线程的start_time是1625558400 + 3 * time_range。这样,每个线程的开始时间都会有所偏移,既确保处理的时间范围没有重叠,又覆盖了整个时间范围。最后,将结果保存在一个列表里,并对列表做升序排序,取得最终结果。
reverse_sql的使用方式如下:
首先修改权限:
shell> chmod 755 reverse_sql
然后查看帮助信息:
shell> ./reverse_sql --help
接着举例说明用法:
shell> ./reverse_sql -ot table1 -op delete -H 192.168.198.239 -P 3336 -u admin -p password -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)。
工具运行时,会先检查MySQL的环境(binlog格式和row image设置)。之后会生成一个{db}_{table}_recover.sql文件,包含原生SQL和反向SQL。可以用--print选项将结果输出到终端。
如果要把update转换为replace,可以指定--replace选项,同时会生成一个{db}_{table}_recover_replace.sql文件。
MySQL用户权限需要授予replication slave、replication client、select权限。
恢复数据
找到误操作的DML语句,在MySQL数据库中执行逆向工程后的SQL以恢复数据。可以通过awk分割recover文件以便排查。
drop和truncate无法恢复,需要通过历史备份恢复。
reverse_sql支持MySQL 5.7/8.0和MariaDB,适用于CentOS 7。
2023年7月12日更新了分之版本,可以实现处理binlog的事件数量和耗时的进度条展示。
下载地址:
https://github.com/hcymysql/reverse_sql/
相关推荐
- JAVA零基础入门:JDK的概述及安装(jdk完整安装教程)
-
一.什么是jdkJDK(JavaDevelopmentToolKit)是Java开发工具包,JDK是整个JAVA的核心,包括了Java运行环境(JavaRuntimeEnvirnment),一...
- 开源、强大的工作流引擎:camunda入门介绍
-
原创不易,请多多支持!对Java技术感兴趣的童鞋请关注我,后续技术分享更精彩。简介CamundaisaJava-basedframeworksupportingBPMNforwork...
- Centos8搭建Java环境(JDK1.8+Nginx+Tomcat9+Redis+Mysql)
-
一、开篇1.1目的每次换新的服务器,都要找资料配下环境,所以我写这篇文章,重新梳理了一下,方便了自己,希望也能给大家带来一些帮助。安装的软件有:JDK1.8+Nginx+Tomcat9+...
- 记录一次tomcat的升级过程(tomcat6升级tomcat8)
-
原因:ApacheTomcat资源管理错误漏洞(CVE-2021-42340)版本:ApacheTomcat/9.0.46,tomcat解决方法:升级tomcat9到最新版本9.0.581.官...
- Tomcat10安装与配置图文教程(tomcat安装及配置)
-
Tomcat10安装与配置图文教程1、百度搜索“tomcat下载”,进入官网下载https://tomcat.apache.org/index.html...
- VS2022配置x86/x64调用32位和64位汇编语言动态库环境
-
配置X86MASM汇编环境1.创建项目打开VS2022创建新项目,新建asm文件(注意要手动修改cpp文件后缀名为asm文件后缀名)。2.设置入口点选择菜单栏中的“调试”-“demo调试属性”-...
- ARM版Win10用户狂喜 微软全新补丁让应用不再不兼容
-
Windows10onARM仅支持模拟32位的X86应用程序,这意味着大多数的桌面应用是无法在这一平台上运行的,这在很大程度上限制该平台的发展。为了解决这一问题,微软在内部开发频道推出可用于AR...
- 分享收藏的 oracle 11.2.0.4各平台的下载地址
-
概述oracle11.2.0.4是目前生产环境用的比较多的版本,同时也是很稳定的一个版本。目前官网上已经找不到下载链接了,有粉丝在头条里要求分享一下下载地址。一、各平台下载地址...
- Android-x86现已基于5.1.1 Lollipop:支持UEFI和64位内核
-
采用Linux内核的Android-x86,旨在为PC带来最新的Android移动操作系统体验。而近日,该操作系统已经发布了Android-x865.1的首个候选发布(RC)版本。发行说明中提到:A...
- Linux Kernel源码阅读: x86-64 系统调用实现细节(二)
-
特别说明:该文章前两天发布过,但一直在审核中。看头条网友说字数太多可能一直处于审核中状态,我把该文章拆分成几个章节发布,如影响阅读体验还请见谅。五、系统调用编号...
- 树莓派4B安装win10后实测,CPU秒杀AMD Athlon64 3200+
-
在上一篇文章介绍了如何给树莓派4B安装win10系统,这篇就简单对系统进行测试,上一篇文章链接https://www.toutiao.com/i7015518822056886821/因为树莓派是a...
- 一键离线部署x86、arm64 RabbitMQ,花了2天去验证整理,直接拿去
-
最近有一个项目,客户是内网网络,只能离线部署,采用的麒麟ARM64服务器系统,不能远程部署,需要提前准备离线部署包让客户IT拷备上去再现场部署,部署时间就只有1天。自家系统采用的vue+springb...
- Linux软件包管理(linux系统软件包的安装方法,并简要说明其特点)
-
Linux系统如果需要安装软件怎么办?如何安装,大概有以下几种方式1.二级制软件包管理(RPM、YUM)...
- Tachyum要做全球最强64位处理器:性能比X86强,面积比ARM小
-
全球半导体芯片研发、生产最强的国家非美国莫属,如果有某家美国公司宣布要开发性能超强的芯片,大家不会意外,但要是一家斯洛伐克初创公司宣布要研发超级芯片呢?Tachyum公司就是这样一家公司,成立于201...
- Android L 64位模拟器终于来了:x86独享
-
GoogleI/O2014大会已经过去了很久,64位的AndroidL依然停留在纸面上,但现在至少可以让开发者们先行品尝品尝了:64位的AndroidL模拟器已经发布。这次公布的模拟器镜像是专...