Mysql数据库恢复到指定时间点

关于备份,参考:https://blog.csdn.net/JSWANGCHANG/article/details/79500917

恢复的顺序:

正常的恢复是先恢复全备,然后恢复增量;

//

全备恢复:mysqldump --single-transaction --flush-logs --master-data=2--all-databases > backup_sunday_1_PM.sql, 恢复全备 mysql

增量恢复:mysqlbinlog gbichot2-bin.000007 gbichot2-bin.000008 | mysql

//

有的时候我们需要恢复到指定时间点;

加入我们做了一系列操作,例如删除表1 material_category_channel

然后再做一些操作,加入删除表2  material_category_config;

现在我发现,我删除表1后,的操作都是错误的,那么我想恢复到这个时间点,而不是恢复整个binlog:

 

 

Step1: 确认当前binlog

Mysql数据库恢复到指定时间点_第1张图片

Step2: 将binlog转换为text,确认时间点

mysqlbinlog mysql-bin.000088 > test1.txt

Mysql数据库恢复到指定时间点_第2张图片

文本中可以看到, 180219 23:54:02 执行前一个;180219 23:57:03执行后一个;如果想恢复前一个不想恢复后一个,则只要把时间定在180219 23:57:02 就可以了;

 

Step3: 将数据恢复到时间点

 

先全备恢复

再时间点恢复:

 

mysqlbinlog--stop-datetime="2018-02-19 23:57:02" mysql-bin.000088 | mysql

查看只有一个表:

Mysql数据库恢复到指定时间点_第3张图片

另外也可以自己选定起点恢复

--start-datetime="2005-04-2010:01:00"

你可能感兴趣的:(mysql)