mysqlbinlog_back.py 是在线读取row格式的mysqld的binlog,然后生成反向的sql语句的工具。
一般用于数据恢复的目的。 所谓反向的sql语句就是如果是insert,则反向的sql为delete。
如果delete,反向的sql是insert,如果是update, 反向的sql还是update,但是update的值是原来的值。
这个项目需要安装依赖
yum install python-pip
pip install pymysql
官方地址:https://github.com/58daojia-dba/mysqlbinlog_flashback
工具使用:
# 查看下参数使用说明
$ python mysqlbinlog_back.py –help
# 回滚某个表
$ python mysqlbinlog_back.py –host=”192.168.1.60″ –port=3306 –username=”root” –password=”yourpassword” –schema=test –tables=”test_tb” -S “mysql-bin.000009”
回滚完成后会在mysqlbinlog_flashback-master/log目录下生成回滚语句
之后执行以下语句在数据库中进行回滚
$ mysql -uroot -pyourpassword –default-character-set=utf8mb4 test < flashback_test_20170912_170610.sql