使用binlog日志还原数据详解

1)看一下你的mysql服务器有没开启binlog日志(ON为开启,OFF为未开启)

show variables like 'log_bin';

 

2)找到你的binlog文件在哪

登录 mysql 后,使用如果命令查看binlog日志名称

show binlog events;

show binary logs;

 当前活动binlog日志文件

show master status;

然后用find命令找一下上面的日志名称(先退出mysql登录状态哦)

find / -name mysql-bin.000001

 

3)确定要还原的内容在哪个日志里

一般日志目录下会有多个日志文件(例如:mysql-bin.000001, mysql-bin.000002, mysql-bin.000003等等),你要先确定你的要还原的部分在哪个或哪几个日志里

 查看binlog日志内容的方法:

#指定节点查看
mysqlbinlog --start-position=134 --stop-position=899 /var/lib/mysql/mysql-bin.000003
#按时间节点查看
mysqlbinlog --start-datetime='2016-12-07 00:00:00' --stop-datetime='2016-12-07 17:32:00' /var/lib/mysql/mysql-bin.000003
#查看指定库
mysqlbinlog --start-datetime='2016-12-07 00:00:00' --stop-datetime='2016-12-07 17:32:00' -d test /var/lib/mysql/mysql-bin.000003
#当然,linux的 | grep 命令也是可以使用的
mysqlbinlog --start-datetime='2016-12-07 00:00:00' --stop-datetime='2016-12-07 17:32:00' /var/lib/mysql/mysql-bin.000003 -d test | grep table1

 

4)恢复数据库前先备份数据

#-l 是锁库的意思,-F 是备份成功后刷新binlog日志的意思,即生成一份新binlog日志文件
mysqldump -uroot -proot share -l -F > /tmp/test20161207.sql

 

5)使用binlog日志还原数据库

#只要在刚刚上面的查看日志的方法后台加 | mysql -u uname -p passwd dbname 就可以还原了
mysqlbinlog --no-defaults --start-position=134 --stop-position=899 /var/lib/mysql/mysql-bin.000003 -d test | mysql -uroot -proot test
#先导出sql数据文件,再进行恢复
mysqlbinlog --no-defaults --start-position=134 --stop-position=899 /var/lib/mysql/mysql-bin.000003 > /tmp/test20161207.sql

#-f 是出错继续的意思
mysql -uroot -proot -f test < /tmp/test20161207.sql

 

6)刷新binlog日志(生成一个新的日志文件)

flush logs;

PS:因为binlog日志记录的是之前的增删改操作,如果后来修改了表结构(增删字段或改变了字段类型),有可能会使之前的sql语句执行错误,还原失败,所以在还原之前要确认一下表结构有没有错误

原文地址:https://www.cnblogs.com/tujia/p/6141349.html