案例: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.sock
mysql> 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 </server/backup/oldboy_2013-06-01.sql 
[root@db02 backup]# mysql -uroot -poldboy123 -S /data/3306/mysql.sock -e "use oldboy;select * from test;"
+----+---------+
| id | name    |
+----+---------+
|  1 | oldboy  |
|  2 | oldgirl |
|  3 | inca    |
|  4 | zuma    |
|  5 | kaka    |
+----+---------+


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.sql
drop database oldboy      #<== 删除此行


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

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


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 |
+----+---------+