本文将讲述怎么通过 MySql 的日志 binlog 文件进行数据恢复。
通过已备份数据 加上 binlog 文件恢复上次备份到删除之间的数据
1、找到最新的 binlog 文件
进入 mysql 命令行执行如下命令
1 | show master status; |
一般最新的编号大,上面最新的就是 binlog.000002
2、找到我们想恢复数据在日志文件里的开始结束位置
这里有两种方式来确定开始位置和结束位置,一种是使用时间作为开始结束,一种是使用日志的 position
作为开始结束位置
2.1、使用时间范围
通过 mysqlbinlog mysql-bin.000002
命令查看日志内容,然后找到删除的时间点:
1 | at 131708213 |
然后确定上次备份的时间点,如果通过日志找不到上次备份的时间点可以填一个你记忆中确定小于上次备份的时间点
2.2、使用 position 范围
使用如下命令查看日志 event 的 position
1 | mysql -uroot -p'password' -e "show binlog events in 'binlog.000002'"|grep -i 'DROP TABLE' |
执行结果如下:
1 | binlog.000002 820474948 Query 1 820475111 use `loongwind_base`; DROP TABLE IF EXISTS `undo_log` /* generated by server */ /* xid=11790691 */ |
即删除的 position 为 820474948
还是通过上述命令,替换关键字查找到上次备份的 position 点
3、恢复
3.1 通过时间恢复
1 | mysqlbinlog --no-defaults --database=loongwind_base --start-datetime="2021-06-07 09:00:00" --stop-datetime="2021-06-10 16:37:58" binlog.000005 | mysql -uroot -p'password' -s -N -f -D loongwind_base |
其中 dxmh_base_hzsy
是数据库名称
3.2 通过 position 恢复
1 | mysqlbinlog --start-position=1178 --stop-position=2751 -d dxmh-sy binlog.000002|mysql -uroot -p'password' -s -N -f -D loongwind_base |
loongwind_base
为数据库名称
如果实在找不到开始时间或者开始 position 也可以不写 --start-datetime
或 --start-position
,这样就是用这个日志文件的开始一直恢复到结束,为了防止与已有数据的冲突,需要加上 -f
即 force
跳过错误继续往下执行。