18

删库了,一定要跑路吗?

 5 years ago
source link: http://mp.weixin.qq.com/s?__biz=MzIyNTM4ODI0OA%3D%3D&%3Bmid=2247484335&%3Bidx=1&%3Bsn=db19464b306c97e34cd1da4886cc66e4
Go to the source link to view the article. You can view the picture content, updated content and better typesetting reading experience. If the link is broken, please click the button below to view the snapshot at that time.
neoserver,ios ssh client

zqqIvq2.jpg!web

在工作中,我们误删数据或者数据库,我们一定需要跑路吗?我看未必,程序员一定要学会自救,神不知鬼不觉的将数据找回。

在 mysql 数据库中,我们知道 binlog 日志记录了我们对数据库的所有操作,所以 binlog 日志就是我们自救的利器。

接下来就来开启程序员自救之路。

想要自救成功,binlog 这把利器一定要好,在自己之前,我们一定要确定我们有 binlog 这把利器,以下就是确保有 binlog 利器的操作。

「1、确认数据库是否开启 binlog 日志」

show variables like 'log_%';
AZ3YF3y.png!web 图片描述

查看红色圈出来的地方,如果为 ON 则表示开启,否则未开启。没有开启的话,就需要做以下操作。

「2、开启 binlog 日志」

如果未开启 binlog 日志的话,就需要开启 binlog 日志,在 MySQL 的配置文件中设置,如果你的是windowns 电脑则找到 my.ini 文件,unix 系统找到 my.cnf 文件。在文件中修改或者配置如下参数:

# Binary Logging.
#日志文件的名字及存储路径
log-bin=D:\Mysql-binlog\mysql-bin
#设置日志格式
binlog-format=mixed

其中 「binlog-format」 有三种选项:

  • 「STATMENT」:每一条会修改数据的 SQL 语句会记录在 binlog 中。

  • 「ROW」:不记录每一条 SQL语句的上下文信息,仅记录哪条记录被修改。

  • 「MIXED」:以上两种模式的混合使用,一般的复制使用STATEMENT模式保存binlog,对于STATEMENT模式无法复制的操作使用ROW模式保存binlog,MySQL会根据执行的 SQL 语句选择日志保存方式。

「3、重启 MySQL 服务器」

「4、再次确认 binlog 日志开启成功。」

好了,操作完上面几步之后,我们就可以学习如何自救了,我们使用三个场景来分别演示误删数据、误删表、误删库的情况下如何自救。

在进入具体的场景前,我们先来准备演示需要的数据库、表和数据。

「1、创建数据库 pingtouge

create database pingtouge;

「2、创建 student 表」

create table student(
   id INT NOT NULL AUTO_INCREMENT,
   name VARCHAR(100) NOT NULL,
   num VARCHAR(40) NOT NULL,
   PRIMARY KEY (id )
)ENGINE=InnoDB DEFAULT CHARSET=utf8;

「3、插入数据」

insert into student(name,num)values('张三','1234');
insert into student(name,num)values('李四','1235');

有了数据之后,可以正式进入场景了, are you ready?

场景一:误删了某条数据

一不小心将 student 表中 id=1 的数据删除了。该怎么办?

Y3U73qF.png!web 图片描述

凭着记忆手动插入这条数据吗?好像也不是不可以哇,能记住的都是天才,利用 binlog 日志才是王道。

使用 show master status 命令,查看最新的 binlog 日志文件。

V7rUreR.png!web 查看最新的 binlog 日志文件

获取到最新的 binlog 日志文件后,使用 show binlog events in 'mysql-bin.000043'; 命令查看 binlog 日志文件,如下图所示:

bqqimeZ.jpg!web binlog 日志文件

binlog 日志记录了我们对数据库的所有操作,包括语句提交前和提交后的偏移量,在数据恢复时会使用到这两个偏移量。

在正式进入数据恢复之前,我们先来认识 MySQL 提供的一个工具:mysqlbinlog 。mysqlbinlog 是用来操作 binlog 日志文件,我们数据恢复就需要使用到它。

使用 mysqlbinlog 来恢复二进制日志文件, 「命令格式」 为:

mysqlbinlog binlog日志文件 --start-position 初始偏移量的位置 --stop-position 结束偏移量的位置 | mysql -u root -p 数据库名称;

我们在 binlog 日志文件中找到 student 表中 id=1 这条数据在删除之前的最后一次操作的起始偏移量和结束偏移量,在上图中,我已经标出,起始偏移量为:710,结束偏移量为:996。有了这两个参数之后,我们就可以使用 mysqlbinlog 命令来恢复数据了。

执行:

mysqlbinlog d:\Mysql-binlog\mysql-bin.000043 --start-position 710 --stop-position 996 | mysql -u root -p pingtouge;

如果命令执行成功的话,再次执行 select * from student 命令,查看数据是否恢复。 2QnUviJ.png!web

从上图中,可以看出,我们成功的恢复了 student 表中 id=1 的这条数据。

场景二:误删了数据表

又是一不小心把表 student 给删除了。

UJfM7fv.png!web 删除表 student

对于误删表,同样可以使用 binlog 日志来恢复,毕竟 binlog 日记记录的是我们对 MySQL 的所有操作,跟恢复单条数据一样,我们同样需要在 binlog 日志文件中查找到起始偏移量和结束偏移量,用来恢复数据。

与单条数据不一样的是, 「对于表的偏移量,起始偏移量是创建表之前的开始偏移量,结束偏移量是删除数据库之前的最后一个结束偏移量。」 如下图示:

ruyY73Y.jpg!webNbYzYv7.jpg!web

一张图截不全,我就分两张图了。同样我们使用 mysqlbinlog 来恢复 student 表,执行:

mysqlbinlog d:\Mysql-binlog\mysql-bin.000043 --start-position 393 --stop-position 1997 | mysql -u root -p pingtouge

命令执行完成后,再次执行 select * from student; ,你会发现我们的数据都回来了。

场景三:误删了数据库

你在工作中受气了,准备删库跑路啦,于是你就把 pingtouge 数据库给删除了,删完之后你就后悔了,怎么办?在线等。

U32Urqu.png!web 删除 pingtouge 数据库

不要慌,万能的 binlog 日志可以救你,跟前面两种场景一样,还是在 binlog 日志中查询到需要恢复数据库的起始偏移量和结束偏移量。这里我就不截图了。

通过查看 binlog 日志发现创建数据库 pingtouge 的开始偏移量为 219,删库之前的最后偏移量为 3861,有了这两个偏移量之后,执行:

mysqlbinlog d:\Mysql-binlog\mysql-bin.000043 --start-position 219 --stop-position 3861 | mysql -u root -p

需要注意的是最后不需要带上数据库,执行完之后,发现与数据库 pingtouge 相关的数据全部都回来了。

删库了,我们不一定需要跑路,一定要学习自救,少年。


Recommend

  • 110

    职场话题 - @niuoh - 阿里云 centos 服务器 今天早上数据库突然被 drop databases 黑客留下了索取 0.1btc 的信息就扬长而去了<br>已经提交了辞职报告<br>mysql 没有 binlo

  • 88
    • blog.51cto.com 6 years ago
    • Cache

    删库了,一定要跑路么?-sery

    上周夜里,一个奢侈品电商网站的程序员手抖,把阿里云rds的某个库给删了,当时都11点多了,心中一万个羊驼在奔腾,还好,没让我出书,小弟就把它给恢复了。昨天上午,又一个网站的程序员手抖,给一个还要用的库给删了。这也不能全怪他,本来计划迁移数据的,因为数...

  • 42
    • blog.51cto.com 6 years ago
    • Cache

    DBA:多方式删库不跑路-小恒Leo

    语法;dropdatabase'DBname';说明:普通mysql用户需要root用户赋特定删除或者创建的权限温馨提醒:删除数据库请多次确认是否要删除,删除数据库是不可逆的操作。一、MySQL内置删库[root@mysql-linuxview~]#mysql-uroot-pEnterpassword:WelcometotheMariaDBmonitor.C...

  • 84

    9 月 19 日,微博网友“大佬坊间八卦”爆料,顺丰科技数据中心的一位高级工程师邓某因误删生产数据库,导致某项服务无法使用并持续 590 分钟。

  • 20

    删库跑路”这件事情真的发生了 ,还是技术总监干的! 我想大道理人人都懂,这个案子的当事人肯定也是有法律意识的,只不过意气用事,心存侥幸,而最终亏了自己。 ...

  • 52

    程序猿(ID:imkuqin) 综合整理 删库容易跑路难,近日,又有一起删库跑路事件发生! 来自微盟官网的消息,

  • 34

    面对员工删库跑路,CIO能做哪些 “从删库到跑路”一直是个笑谈,好笑的地方就在于,他总是发生在别人的公司。但是如果发生在自己部门,估计没哪个CIO能笑出来了。 作...

  • 17

    作者介绍 杨建荣, dbaplus社群联合发起人,竞技世界资深DBA,前搜狐畅游数据库专家,Oracle ACE,腾讯云TVP。具有十多年数据库开发和运维经验,目前专注于开源技术、运维自动化和性能调优。《Oracle/MySQL...

  • 38

    日常工作中,总会有因手抖、写错条件、写错表名、错连生产库造成的误删库表和数据的事情发生。那么,如果连数据都恢复不了,还要什么 DBA。1. 前言数据恢复的前提的做好备份,且开启 binlog,格式为 row。如果没有备份文件,那么删掉库表后就真的删掉了,lsof 中还...

  • 22
    • 微信 mp.weixin.qq.com 4 years ago
    • Cache

    思科前员工删库跑路,损失达 1600 多万

    点击上方 蓝色小字 ,关注 “ 涛哥聊Python ” 重磅干货,第一时间送达

About Joyk


Aggregate valuable and interesting links.
Joyk means Joy of geeK