1.在测试数据库mydb测试表tb1现有数据并使用innobackupex 将数据全量备份至/backup目录下:
innobackupex -uroot -p123456 -H172.18.100.103 /backup/
备份现在存有的数据中tb1只有一条数据
2.往表tb1中继续插入2条数据:
此时tb1有,a,b,c三条数据
3.查看此时数据库正在使用的二进制文件:
show master status
4.进入mysql数据目录将该二进制日志复制
5.模拟故障将mydb测试库drop掉:
drop database mydb;
6.此时mydb数据中的已经被删掉了,此时可以直接使用二进制日志恢复数据,这里不演示这种方式。采取使用innobackex备份数据恢复至备份时间点。
innobackex -uroot -p123456 -H172.18.224.103 --apply-log /backup/备份文件目录
7.将备份文件复制到mysql数据目录下:
停止mysql实例,并将原来的数据文件目录mysql改名,将备份文件夹改名为mysql,并授予权限,重启mysql实例恢复成功
systemctl stop mysqld
mv mysql mysql_bak2
mysql /备份文件 mysql
chown -R mysql.mysql mysql
systemctl start mysqld
8.查看tb1发现只有1条数据a,剩下的2条数据通过二进制文件恢复
通过mysqlbinlog工具找到之前的数据:
mysqlbinlog -v bin-log.000004|grep -C 15 -i 'drop database'
mysqlbinlog查看二进制日志并通过管道符传给grep
grep -C 15 输出查找到的数据上下文15行数据,-i 指定查找的内容
这里看到之前insert插入2条数据的起始位置为2687,drop 删库操作起始位置为2895,所以需要恢复的开始位置为2687,结束位置为2895
9.使用mysqlbinlog恢复数据:
mysqlbinlog --start-position=2687 --stop-position=2895 bin-log.000004 |mysql -uroot -p123456 -h172.18.224.103
--start-position 开始位置
--stop-position 结束位置
并将该结果通过管道符传送给mysql -uroot -p123456 -h172.18.224.103执行
10.连入mysql验证数据是否恢复成功:
恢复成功
11.mysql数据库中使用show binlog events in 'bin-log.000004'也可以查看到对应的事务:
总结:1.mysql的二进制日志非常有用,备份的时候最好也要将二进制日志备份以备不时之需
2.在生产环境中可以使用xtrabackup+mysql二进制日志结合实现对数据的备份与恢复