使用binlog,实现MySQL数据恢复
mysql的binlog日志,用于记录数据库的增、删、改等修改操作,默认处于关闭状态。使用binlog实现数据恢复的条件为
1、binlog日志功能已开启
2、若binlog在数据库创建一段时候后开启,则实现恢复数据需要基于binlog开启之后某一时刻的数据备份
3、binlog工作在Statement level(默认)模式,隔离级别为 repeatable read 时,采用乐观锁并发插入数据,可能发生死锁
乐观锁: insert into A
select a, b, c from dual
where exists(select 1 from dual where '...' = (select max(...) from A))
错误信息:Deadlock found when trying to get lock; try restarting transaction
隔离级别为read committed 时,依然报错:impossible to write to binary log since BINLOG_FORMAT = STATEMENT and at least one table uses a storage engine limited to row-based logging
即便查询和插入的数据范围不重合(如不同客户同时插入数据),依然如此;binlog工作在Mixed模式下不存在该情况,具体原因待研究
binlog的使用及数据恢复过程,可参考一下分享: