第一步:保证mysql已经开启binlog,查看命令:
查看binklog是否开启
show variables like '%log_bin%';
查看binlog存放日志文件目录(如下图,博主binlog目录为/data/mysql):
show variables like '%datadir%';
值为OFF,需开启,值为ON,已开启。
如果没有开启binlog,也没有预先生成回滚SQL,那可能真的无法快速回滚了。对存放重要业务数据的MySQL,强烈建议开启binlog。
第二步:进入binlog文件目录,找出日志文件
第三步:切换到mysqlbinlog目录(当线上数据出现错误的时候首先可以询问具体操作人记录时间点,这个时候可以借助mysql自带的binlog解析工具mysqlbinlog,具体位置在mysql安装目录**/mysql/bin/下)
第四步:通过mysqlbinlog工具命令查看数据库增删改查记录(必须切换到mysqlbinlog目录才有效)
例子1:查询2018-11-12 09:00:00到2018-11-13 20:00:00 数据库为 youxi 的操作日志,输入如下命令将数据写入到一个备用的txt文件中
mysqlbinlog --no-defaults --database=youxi --start-datetime="2018-11-12 09:00:00" --stop-datetime="2018-11-13 20:00:00" /data/mysql/mysql-bin.000015 > template_coupon_tb_product_category.txt
例子2:查询2018-11-12 09:00:00到2018-11-13 20:00:00 数据库为 youxi 的操作日志,并输出到屏幕上
mysqlbinlog --no-defaults --database=youxi --start-datetime="2018-11-12 09:00:00" --stop-datetime="2018-11-13 20:00:00" /data/mysql/mysql-bin.000015 |more
例子3:查询2018-11-12 09:00:00到2018-11-13 20:00:00 数据库为 youxi 的操作日志,并且过滤出 只包括 template_coupon_tb_product_category 表数据的操作记录 ,输入如下命令将数据写入到一个备用的txt文件中
mysqlbinlog --no-defaults --database=youxi --start-datetime="2018-11-12 09:00:00" --stop-datetime="2018-11-13 20:00:00" /data/mysql/mysql-bin.000015 | grep template_coupon_tb_product_category > template_coupon_tb_product_category.txt
第五步:利用第四步输出的sql语句或者txt文本进行语句过滤,重新插入数据或更新数据
以上方法可能会出现sql语句字段缺失的情况:如图,上面一整段数据都是好的,下面的sql语句有缺失
如遇到以上问题可以尝试使用下面的方法:
通过下面的命令将指定binlog二进制日志文件中的sql自动执行一遍,区别于上面打印到txt文档中的方法
[root@localhost bin]# ./mysqlbinlog --no-defaults /www/server/data/mysql-bin.000004 --start-position="794" --stop-position="1055" | /www/server/mysql/bin/mysql -uroot -p123456 test
或
[root@localhost bin]# ./mysqlbinlog --no-defaults /www/server/data/mysql-bin.000004 --start-datetime="2020-12-15 00:00:00" --stop-datetime="2021-03-01 20:00:00" | /www/server/mysql/bin/mysql -uroot -psw
start-position 代表指定具体开始位置
start-datetime 代表指定具体开始日期