千家信息网

操作MySQL误删数据库备份该如何恢复

发表于:2024-11-23 作者:千家信息网编辑
千家信息网最后更新 2024年11月23日,下文主要给大家带来操作MySQL误删数据库备份该如何恢复,希望这些内容能够带给大家实际用处,这也是我编辑操作MySQL误删数据库备份该如何恢复这篇文章的主要目的。好了,废话不多说,大家直接看下文吧。案
千家信息网最后更新 2024年11月23日操作MySQL误删数据库备份该如何恢复

下文主要给大家带来操作MySQL误删数据库备份该如何恢复,希望这些内容能够带给大家实际用处,这也是我编辑操作MySQL误删数据库备份该如何恢复这篇文章的主要目的。好了,废话不多说,大家直接看下文吧。

案例:2013年6月1日,上午10点左右某网站的数据库被误删除,导致网站无法访问,由于数据库已经备份了6月1日凌晨0点之前的数据,但是0点之后到10点左右的数据就没有备份数据,那么要求你将数据库中的所有数据进行恢复。

一:数据记录介绍

6月1日0点之前的数据为

|  1 | oldboy  ||  2 | oldgirl ||  3 | inca    ||  4 | zuma    ||  5 | kaka    |# 6月1日0点之后到10点左右写入的数据为|  6 | oldgirl ||  7 | test    ||  8 | laowang |

二:模拟事故的发生准备

1.为了不影响本次实验,我们先将系统的定时任务。

[root@db01 ~]# crontab -l#*/5 * * * * /usr/sbin/ntpdate time.nist.gov >/dev/null 2>&1

2.先将使用时间调整至凌晨0点,每天00点进行数据库备份

[root@db01 backup]# date -s "2013/06/01"Mon Aug 29 00:00:00 CST 2016

3.先检查数据库有哪些数据

[root@db01 ~]# mysql -uroot -poldboy123 -S /data/3306/mysql.sockmysql> use oldboy;

创建一个test表测试

CREATE TABLE `test` (`id` int(4) NOT NULL AUTO_INCREMENT,`name` char(20) NOT NULL,PRIMARY KEY(`id`));

向表中插入数据

insert into test values (1,'oldboy'),(2,'oldgirl'),(3,'inca'),(4,'zuma'),(5,'kaka');mysql> select * from test;+----+---------+| id | name    |+----+---------+|  1 | oldboy  ||  2 | oldgirl ||  3 | inca    ||  4 | zuma    ||  5 | kaka    |+----+---------+5 rows in set (0.00 sec)

4.首先对oldboy数据库进行全量备份

下面的参数--master-data=2需要开启binlog日志

[root@db02 ~]# mysqldump -uroot -poldboy123 -S /data/3306/mysql.sock -B -F -x --master-data=2 oldboy|gzip >/server/backup/oldboy_$(date +%F).sql.gz     #<== -x  表示备份数据库锁表

检查新生产的binlog日志

[root@db02 ~]# ll /data/3306/-rw-rw----  1 mysql mysql    107 Jun  1 00:02 mysql-bin.000070

5.检查数据库是否备份成功

[root@db01 ~]# ll /server/backup/-rw-r--r-- 1 root root 872 Jun  1 00:02 oldboy_2013-06-01.sql.gz

6.然后望数据库写入一些数据,模拟备份完成以后数据库还依旧在写入数据

[root@db02 ~]# mysql -uroot -poldboy123 -S /data/3306/mysql.sock   mysql> use oldboy;mysql> insert into test values(6,'oldgirl'),(7,'test'),(8,'laowang');mysql> select * from test;+----+---------+| id | name    |+----+---------+|  1 | oldboy  ||  2 | oldgirl ||  3 | inca    ||  4 | zuma    ||  5 | kaka    ||  6 | oldgirl ||  7 | test    ||  8 | laowang |+----+---------+8 rows in set (0.00 sec)

三:制造故障发生

假设上午10点:

出事了,

某个领导,误删了数据库oldboy

7.现在模拟早上10点发生故障,数据库oldboy被删除,先修改时间

[root@db02 ~]# date -s "10:00:00"Mon Aug 29 10:00:00 CST 2016[root@db02 ~]# mysql -uroot -poldboy123 -S /data/3306/mysql.sock -e "drop database oldboy;" Query OK, 1 row affected, 1 warning (0.01 sec)

#检查数据库是否删除成功

mysql -uroot -poldboy123 -S /data/3306/mysql.sock -e "show databases;" 

四:解决问题,恢复数据

10:10分,运维人员,网站客户,发现问题,找到开发或运维

最后确定问题,网站的数据库连接不上,报错。登录数据库发生数据库不存在啦

8.现在我们来解决问题,恢复数据库

首先我们需要知道备份以后产生的binlog日志,可以通过备份的时间判断。

[root@db02 ~]# ll /data/3306/-rw-rw----  1 mysql mysql    107 Jun  1 00:02 mysql-bin.000070

9.如果看不出来的话,看备份文件的信息,

[root@db02 ~]# cd /server/backup/[root@db02 backup]# gzip -d oldboy_2013-06-01.sql.gz[root@db02 backup]# grep "CHANGE" oldboy_2013-06-01.sql -- CHANGE MASTER TO MASTER_LOG_FILE='mysql-bin.000070', MASTER_LOG_POS=107

10.先将mysql-bin.000070的binlog日志进行备份

[root@db02 ~]# cp /data/3306/mysql-bin.000070 /server/backup/[root@db02 ~]# ll /server/backup/total 8-rw-r----- 1 root root  415 Jun  1 10:04 mysql-bin.000070      #<== 增量备份文件-rw-r--r-- 1 root root 2203 Jun  1 00:02 oldboy_2013-06-01.sql      #<== 全量备份文件

11.根据上面的情况,我们已经准备好了全量备份加增量备份的数据,现在就可以恢复

我们的目的,

(1)恢复00点之前的全量备份(5条数据)

[root@db02 ~]# mysql -uroot -poldboy123 -S /data/3306/mysql.sock 

12恢复00点到10点的增量备份(2条数据)

[root@db02 ~]# cd /server/backup/[root@db02 backup]# mysqlbinlog -d oldboy mysql-bin.000070 >zengliang.sql

13先找到binlog日志的drop语句删除,然后在恢复binglog日志的增量备份

[root@db02 backup]# vim zengliang.sqldrop database oldboy      #<== 删除此行

14.现在将数据库的增量备份文件恢复到数据库

[root@db02 backup]# mysql -uroot -poldboy123 -S /data/3306/mysql.sock 

15只要能恢复到以下的数据,就表示数据恢复成功

[root@db01 backup]# mysql -uroot -poldboy123 -S /data/3306/mysql.sock -e 'select * from oldboy.test;'+----+---------+| id | name    |+----+---------+|  1 | oldboy  ||  2 | oldgirl ||  3 | inca    ||  4 | zuma    ||  5 | kaka    ||  6 | oldgirl ||  7 | test    ||  8 | laowang |+----+---------+

对于以上关于操作MySQL误删数据库备份该如何恢复,大家是不是觉得非常有帮助。如果需要了解更多内容,请继续关注我们的行业资讯,相信你会喜欢上这些内容的。

0