如何解决线上数据库删了的问题
本篇内容主要讲解“如何解决线上数据库删了的问题”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“如何解决线上数据库删了的问题”吧!
事件背景
MySQL数据库每日零点自动全备
某天上午9点,二狗子不小心drop了一个数据库
我们需要通过全备的数据文件,以及增量的binlog文件进行数据恢复
主要思想与原理
利用全备的sql文件中记录的CHANGE MASTER语句,binlog文件及其位置点信息,找出binlog文件增量的部分
用mysqlbinlog命令将上述的binlog文件导出为sql文件,并剔除其中的drop语句
通过全备文件和增量binlog文件的导出sql文件,就可以恢复到完整的数据
过程示意图
操作过程
模拟数据
CREATETABLE`student`(`id`int(11)NOTNULLAUTO_INCREMENT,`name`char(20)NOTNULL,`age`tinyint(2)NOTNULLDEFAULT'0',PRIMARYKEY(`id`),KEY`index_name`(`name`))ENGINE=InnoDBAUTO_INCREMENT=8DEFAULTCHARSET=utf8mysql>insertstudentvalues(1,'zhangsan',20);mysql>insertstudentvalues(2,'lisi',21);mysql>insertstudentvalues(3,'wangwu',22);
全备命令
#mysqldump-uroot-p-B-F-R-x--master-data=2test|gzip>/server/backup/test_$(date+%F).sql.gz
参数说明:
-B 指定数据库
-F 刷新日志
-R 备份存储过程等
-x 锁表
--master-data 在备份语句里添加CHANGE MASTER语句以及binlog文件及位置点信息
继续插入数据并删库
mysql>insertstudentvalues(4,'xiaoming',20);mysql>insertstudentvalues(5,'xiaohong',20);
在插入数据的时候我们模拟误操作,删除test数据库。
mysql>dropdatabasetest;
此时,全备之后到误操作时刻之间,用户写入的数据在binlog中,需要恢复出来。
查看全备之后新增的binlog文件
#cd/server/backup/#lstest_2020-08-19.sql.gz#gzip-dtest_2020-08-19.sql.gz#grepCHANGEtest_2020-08-19.sql--CHANGEMASTERTOMASTER_LOG_FILE='mysql-bin.000003',MASTER_LOG_POS=107;
这是全备时刻的binlog文件位置,即mysql-bin.000003的107行,因此在该文件之前的binlog文件中的数据都已经包含在这个全备的sql文件中了
移动binlog文件,并读取sql,剔除其中的drop语句
#cp/data/3306/mysql-bin.000003/server/backup/#mysqlbinlog-dtestmysql-bin.000003>mysql-bin.000003.sql
接下来,使用vim编辑mysql-bin.000003.sql文件,剔除drop语句
注意:在恢复全备数据之前必须将该binlog文件移出,否则恢复过程中,会继续写入语句到binlog,最终导致增量恢复数据部分变得比较混乱
恢复数据
#mysql-uroot-p<test_2020-08-19.sql#mysql-uroot-p-e"select*fromtest.student;"+----+----------+-----+|id|name|age|+----+----------+-----+|1|zhangsan|20||2|lisi|21||3|wangwu|22|+----+----------+-----+
此时恢复了全备时刻的数据,然后使用mysql-bin.000003.sql文件恢复全备时刻到删除数据库之间,新增的数据。
#mysql-uroot-ptest<mysql-bin.000003.sql#mysql-uroot-p-e"select*fromtest.student;"+----+----------+-----+|id|name|age|+----+----------+-----+|1|zhangsan|20||2|lisi|20||3|wangwu|20||4|xiaoming|20||5|xiaohong|20|+----+----------+-----+
此时,整个恢复过程结束,是不是很简单呢?没错,就是这么简单!!
到此,相信大家对“如何解决线上数据库删了的问题”有了更深的了解,不妨来实际操作一番吧!这里是亿速云网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!
声明:本站所有文章资源内容,如无特殊说明或标注,均为采集网络资源。如若本站内容侵犯了原著者的合法权益,可联系本站删除。