操作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.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 |
+----+---------+

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

另外有需要云服务器可以了解下创新互联cdcxhl.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。

网站栏目:操作MySQL误删数据库备份该如何恢复-创新互联
浏览地址:https://www.cdcxhl.com/article42/eeihc.html

成都网站建设公司_创新互联,为您提供品牌网站设计全网营销推广域名注册外贸建站网站建设网页设计公司

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联

绵阳服务器托管