网创优客建站品牌官网
为成都网站建设公司企业提供高品质网站建设
热线:028-86922220
成都专业网站建设公司

定制建站费用3500元

符合中小企业对网站设计、功能常规化式的企业展示型网站建设

成都品牌网站建设

品牌网站建设费用6000元

本套餐主要针对企业品牌型网站、中高端设计、前端互动体验...

成都商城网站建设

商城网站建设费用8000元

商城网站建设因基本功能的需求不同费用上面也有很大的差别...

成都微信网站建设

手机微信网站建站3000元

手机微信网站开发、微信官网、微信商城网站...

建站知识

当前位置:首页 > 建站知识

如何解决线上数据库删了的问题

本篇内容主要讲解“如何解决线上数据库删了的问题”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“如何解决线上数据库删了的问题”吧!

我们提供的服务有:成都网站设计、网站制作、微信公众号开发、网站优化、网站认证、池州ssl等。为近千家企事业单位解决了网站和推广的问题。提供周到的售前咨询和贴心的售后服务,是有科学管理、有技术的池州网站制作公司

事件背景

  • MySQL数据库每日零点自动全备

  • 某天上午9点,二狗子不小心drop了一个数据库

  • 我们需要通过全备的数据文件,以及增量的binlog文件进行数据恢复

主要思想与原理

  • 利用全备的sql文件中记录的CHANGE MASTER语句,binlog文件及其位置点信息,找出binlog文件增量的部分

  • 用mysqlbinlog命令将上述的binlog文件导出为sql文件,并剔除其中的drop语句

  • 通过全备文件和增量binlog文件的导出sql文件,就可以恢复到完整的数据

过程示意图

如何解决线上数据库删了的问题

操作过程

模拟数据

CREATE TABLE `student` (   `id` int(11) NOT NULL AUTO_INCREMENT,   `name` char(20) NOT NULL,   `age` tinyint(2) NOT NULL DEFAULT '0',   PRIMARY KEY (`id`),   KEY `index_name` (`name`) ) ENGINE=InnoDB AUTO_INCREMENT=8 DEFAULT CHARSET=utf8    mysql> insert student values(1,'zhangsan',20);  mysql> insert student values(2,'lisi',21);  mysql> insert student values(3,'wangwu',22);

全备命令

# mysqldump -uroot -p -B -F -R -x --master-data=2 test|gzip >/server/backup/test_$(date +%F).sql.gz

参数说明:

  • -B 指定数据库

  • -F 刷新日志

  • -R 备份存储过程等

  • -x 锁表

  • --master-data 在备份语句里添加CHANGE MASTER语句以及binlog文件及位置点信息

继续插入数据并删库

mysql> insert student values(4,'xiaoming',20); mysql> insert student values(5,'xiaohong',20);

在插入数据的时候我们模拟误操作,删除test数据库。

mysql> drop database test;

此时,全备之后到误操作时刻之间,用户写入的数据在binlog中,需要恢复出来。

查看全备之后新增的binlog文件

# cd /server/backup/ # ls test_2020-08-19.sql.gz # gzip -d test_2020-08-19.sql.gz  # grep CHANGE test_2020-08-19.sql  -- CHANGE MASTER TO MASTER_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 -d test mysql-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 * from test.student;" +----+----------+-----+ | id | name     | age | +----+----------+-----+ |  1 | zhangsan |  20 | |  2 | lisi     |  21 | |  3 | wangwu   |  22 | +----+----------+-----+

此时恢复了全备时刻的数据,然后使用mysql-bin.000003.sql文件恢复全备时刻到删除数据库之间,新增的数据。

# mysql -uroot -p test < mysql-bin.000003.sql  # mysql -uroot -p -e "select * from test.student;" +----+----------+-----+ | id | name     | age | +----+----------+-----+ |  1 | zhangsan |  20 | |  2 | lisi     |  20 | |  3 | wangwu   |  20 | |  4 | xiaoming |  20 |  |  5 | xiaohong |  20 | +----+----------+-----+

此时,整个恢复过程结束,是不是很简单呢?没错,就是这么简单!!

到此,相信大家对“如何解决线上数据库删了的问题”有了更深的了解,不妨来实际操作一番吧!这里是创新互联网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!


分享文章:如何解决线上数据库删了的问题
网页网址:http://bjjierui.cn/article/ihospp.html

其他资讯