我一直在想,地球上这么多程序员,应该有很多人在团队做项目的时候,出过很大的错误,比如说不小心删了库,活动福利字段多写了个零导致全服务器玩家领到数倍奖励,听了沙雕群友的话执行rm -rf命令。

记得有一本专门调侃的书,叫《Mysql从入门到删库跑路》,各种能人异士。

所以掌握如何在数据库被删之后进行恢复,是很重要的。

MySQL删除数据有很多种方式,你可以删除一条数据,可以删除一张表,也可以删除一整个库,还有就是你在rm -rf删除磁盘的时候直接把MySQL相关的所有文件都给删了。

删除行

如果你使用delete命令删除了一行数据,可以使用Flashback工具通过闪回来恢复数据。

如果你使用过git,应该知道它有一个很有用的命令,Revert,回到之前的状态。

对于数据库也是类似,我们的每一步操作其实都是记录在binlog中的,要恢复一条数据,只需要按照binlog中的操作记录进行回滚。

对于binlog中DELETE的操作,回滚就会执行与之对应的INSERT操作。

同理,INSERT的回滚是DELETE。

UPDATE的回滚,是交换前后SET和WHERE的值,这个请思考一下UPDATE语句的WHERE和SET作用。

原始:

UPDATE test.user SET id=3, name='antz' WHERE id=3 AND name='uhl';

回滚:

UPDATE test.user SET id=3, name='uhl' WHERE id=3 AND name='antz';

所以说,我们只需要知道我们删除时执行了哪些DELETE语句,就可以把这个DELETE反过来改写成为INSERT语句,达到恢复的目的。

为了方便这里使用binlog2sql工具来帮助我们分析binlog日志。

git clone https://github.com/danfengcao/binlog2sql.git
cd binlog2sql
pip install -r requirements.txt

查看开始时的binlog日志状态。

删除一条数据之后的binlog。

执行脚本解析binlog。

不过最好还是不要在主库上这样做,说不定越来越乱。

最好可以把你要恢复的库拷贝出一个备份,在这个库上临时进行恢复,确认恢复成功后,在恢复到主库。

这是因为,一个在执行线上逻辑的主库,数据状态的变更往往是有关联的,可能发现数据问题的时间晚一点,就导致已经在之前误操作的基础上,业务逻辑代码就继续修改了其他数据,如果你直接在主库恢复了这几条数据,没有经过确认的话,可能会导致数据出现更大问题。

你可以把sql_safe_updates参数设置为on,这样你的delete和update在没有写where的情况下就会报错。

误删库/表

这种情况下想要恢复数据就需要使用全量备份,加增量日志的方式了。要求线上数据库有定期的全量备份,并且实时备份binlog。

假如说有一个人不小心删掉一个库,我们就可以取最近的一次全量备份,恢复出一个临时库,然后在拿出当前的日志,从日志中恢复全量备份中没有的数据。

MySQL自带了一个binlog查看的工具,mysqlbinlog,在你MySQL安装目录下的bin中就可以找到。

使用show master logs查看当前的binlog日志,找到最近的一条,就可以使用mysqlbinlog来查看了。

rm删除

这类情况一般来说就只有跑路了,除非你使用了Mysql集群,你可以从其他节点中恢复数据。

Mysql如何在删库后可以不用跑路的更多相关文章

  1. 写了Bug,误执行 rm -fr /*,我删删删删库了,要跑路吗?

    每日英语,每天进步一点点(偷笑): 前言 临近五一节,想到有 5 天假期,小林开始飘了. 写个简单的 Bash 脚本都不上心了,写完连检查都不检查,直接拖到到实体服务器跑. 结果一跑起来,发生不对劲, ...

  2. 学会这个删库再也不用跑路了~ --技术流ken

    前言 相信每一个学IT的人或多或少都听说过从删库到跑路这个梗~下图也是在各种交流群屡禁不止,新人听着也是瑟瑟发抖. 人们茶余饭后,街头巷角难免要问... 下面技术流ken就教给各位新手们一招删库再也不 ...

  3. 搭建mysql主从复制和删库数据恢复策略

    搭建主从复制 主机: [mysqld] 下增加 vim /etc/my.cnf ## 设置 server_id,一般设置为 IP server_id=8 # # 复制过滤:需要备份的数据库,输出 bi ...

  4. MySQL 多实例删库脚本

    DB版本:5.5.14 OS:CentOS 6.3 在测试环境中,在一台服务器上创建多个实例,在每个实例中一个一个删库比较麻烦,因此用下面脚本,可以直接删除所有库,除了系统库以外: #!/bin/ba ...

  5. mysql数据库从删库到跑路之mysql存储引擎

    一 什么是存储引擎 mysql中建立的库===>文件夹 库中建立的表===>文件 现实生活中我们用来存储数据的文件应该有不同的类型:比如存文本用txt类型,存表格用excel,存图片用pn ...

  6. mysql数据库从删库到跑路之mysql基础

    一 数据库是什么 之前所学,数据要永久保存,比如用户注册的用户信息,都是保存于文件中,而文件只能存在于某一台机器上. 如果我们不考虑从文件中读取数据的效率问题,并且假设我们的程序所有的组件都运行在一台 ...

  7. mysql数据库从删库到跑路之mysql其他

    一 IDE工具介绍 生产环境还是推荐使用mysql命令行,但为了方便测试,可以使用IDE工具 下载链接:https://pan.baidu.com/s/1bpo5mqj 掌握: #1. 测试+链接数据 ...

  8. mysql数据库从删库到跑路之mysql库操作

    一 知识储备 MySQL数据库基本操作知识储备 数据库服务器:一台计算机(对内存要求比较高) 数据库管理系统:如mysql,是一个软件 数据库:oldboy_stu,相当于文件夹 表:student, ...

  9. mysql数据库从删库到跑路之mysql表操作

    表介绍 表相当于文件,表中的一条记录就相当于文件的一行内容,不同的是,表中的一条记录有对应的标题,称为表的字段 id,name,qq,age称为字段,其余的,一行内容称为一条记录 内容: 1 创建表 ...

随机推荐

  1. English:Day-to-day 1014

    Piracy Defy Coordination Essential Globe Silky Threat Supply Haste Ample Correspond Beloved Adjust D ...

  2. Abp zero 登录 添加腾讯云验证码

    腾讯云验证码是为网页.App.小程序开发者提供的安全验证服务,基于腾讯多年的大数据积累和人工智能决策引擎,构建智能分级验证模型,最大程度保护业务安全的同时,提供更精细化的用户体验. 腾讯云--> ...

  3. SpringCloudGateWay修改请求路径,从注册中心获得服务

    SpringCloudGateWay修改请求路径,从注册中心获得服务 @Resource    private DiscoveryClient disClient;    @Resource    p ...

  4. Django实现标签联动以及xadmin中实现标签联动

    如图,即实现点击一个城市,出现对应的学校名称.开始一直以为是建立数据表的时候实现的,原来是通过ajax实现的. 思路:当get请求显示原始状态(即下拉框呈现全部内容).当点击一个城市后,通过ajax的 ...

  5. Ubuntu下配置IP地址

    17.10版本之前: Ubuntu的网卡配置文件跟CentOS的不一样,Ubuntu的网卡配置文件是/etc/network/interfaces.我们用vi /etc/network/interfa ...

  6. 28.分类算法---KNN

    1.工作原理: 存在一个样本数据集合,也称为训练样本集,并且样本集中每个数据都存在标签,即我们知道样本集中每一数据与所属分类对应的关系.输入没有标签的数据后,将新数据中的每个特征与样本集中数据对应的特 ...

  7. Ubuntu16.04VIM无法补全错误记录

    先记录一下YouCompleteMe的安装过程. 按照教程进行安装 1. 安装 vundle # vundle是vim的包管理器,十分好用 cv@cv: ~$ git clone https://gi ...

  8. SpringBoot源码学习系列之Locale自动配置

    目录 1.spring.messages.cache-duration 2.LocaleResolver 的方法名必须为localeResolver 3.默认LocaleResolver 4.指定默认 ...

  9. 软件测试价值提升之路- 第二章"价值实现的起点"读书笔记

    价值实现的起点 2.1 打破常规 打破哪些已经不适应现在软件开发需要的“准则”,明确需要在什么样的环境下.瞄准什么目标来实现测试的价值 找风险:研发内部测试 测试最基础的是找bug,但需要根据风险找最 ...

  10. Maven学习 --- <distributionManagement>

    在使用maven过程中,我们在开发阶段经常性的会有很多公共库处于不稳定状态,随时需要修改并发布,可能一天就要发布一次,遇到bug时,甚至一天要发布N次.我们知道,maven的依赖管理是基于版本管理的, ...