MYSQL数据闪回方式

MYSQL官方截止目前还没有出来数据闪回特性,也许后续版本会出现。社区有一些开源工具可以使用,沿用的基本都是彭立勋最早提出的思路,利用binlog对SQL进行反向解析,从而实现数据闪回,例如不带where条件的update操作,导致全表数据被误更新。

闪回前提:

binlog_format = ROW

操作模拟:

没加where条件,导致全表更新;或者没加host列,导致多余行被更新。

我只想把user=test_user1,host=1.1.1.1改密码,但是没加host条件。此时并没有及时发现,直到报错才意识到操作失误。如果直到之前的密码那也还好,如果不知道就需要做数据恢复了。

闪回方式:

一、利用mysql自带的mysqlbinlog命令解析binlog,再通过grep、sed等命令把binlog中相关SQL误操作给逆向回来,然后导入SQL文件来恢复错误操作。

  1. 根据当时操作时间解析binlog
mysqlbinlog -v --base64-output=decode-rows mysql-bin.000011 --start-datetime="2017-11-27 11:40:00" --stop-datetime="2017-11-27 12:00:00" | egrep -A4 -i  'UPDATE `mysql`.`user`|### SET' > rollback.sql
  1. 将解析出来的日志再进行处理,将where和set数据反转后再导入恢复
  2. 这种方式比较麻烦,需要自己写一套转换脚本

二、利用彭立勋提供的工具mysqlbinlog,只支持5.5版本,随后社区提供了支持5.6以上版本工具

5.5版本:https://pan.baidu.com/s/1qXB8Zxy

5.6以上版本:https://pan.baidu.com/s/1dFtUNlf

  1. 下载对应版本的工具 绝对路径:/mysqlbinlog -v -B mysql-bin.000011 --base64-output=decode-rows --start-datetime="2017-11-27 11:40:00" --stop-datetime="2017-11-27 12:00:00" > rollback.sql
  2. 此工具自动将where和set数据反转
  3. 将注释去掉直接恢复即可

三、mysqlbinlog2sql、mysqlbinlog_flashback(类似二)

下载:git clone https://github.com/danfengcao/binlog2sql.git && cd binlog2sql

pip install -r requirements.txt

  1. python binlog2sql.py -uroot -h127.0.0.1 -p -dmysql --start-file='mysql-bin.000011' -B --start-datetime='2017-11-27 11:40:00' --stop-datetime="2017-11-27 12:00:00" > rollback.sql
  2. 此工具自动将where和set数据反转

四、脚本binlog_rollback.py

下载:https://pan.baidu.com/s/1c2D9Elq

  1. python binlog_rollback.py -f mysql-bin.000011 -uroot -p --start-datetime='2017-11-27 11:40:00' --stop-datetime="2017-11-27 12:00:00" -d mysql -o rollback.sql
  2. 此工具自动将where和set数据反转
  3. 将sql直接source即可

以上四种方式其实原理都一样,都是对binlog进行解析,再讲sql反向应用,达到恢复的效果,有时间可以试验一下。

> mysqlbinlog -v -B mysql-bin.000011 --base64-output=decode-rows --start-datetime="2017-11-27 11:40:00" | egrep -A4 -i  'UPDATE `mysql`.`user`|### SET'

UPDATE `mysql`.`user` WHERE @1='1.1.1.1' @2='test_user1' @3='*2A032F7C5BA932872F0F045E0CF6B53CF702F2C5' -- SET @1='1.1.1.1' @2='test_user1' @3='*6BB4837EB74329105EE4568DDA7DC67ED2CA2AD9' @4=2

原文发布于微信公众号 - MYSQL轻松学(learnmysql)

原文发表时间:2017-11-27

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏云计算教程系列

如何在CentOS上安装MySQL

MySQL是一种流行的数据库管理系统,用于Web和服务器应用程序。本教程将介绍如何在CentOS 6上安装,配置和管理MySQL。

1397
来自专栏决胜机器学习

数据库专题(一) ——数据库优化

数据库专题(一) ——数据库优化 (原创内容,转载请注明来源,谢谢) 一、概述 数据库的优化通常分为三个方面:数据库DML、DQL的优化(即增删改查等SQL语...

3108
来自专栏云计算教程系列

如何在Ubuntu 16.04上安装和配置Sphinx

Sphinx是一个开源搜索引擎,允许全文搜索。众所周知,它能非常有效地对大数据进行搜索。要编制索引的数据通常来自非常不同的来源:SQL数据库,纯文本文件,HTM...

1230
来自专栏一枝花算不算浪漫

[Linux]Linux下安装和配置solr/tomcat/IK分词器 详细实例二.

33410
来自专栏Laoqi's Linux运维专列

再讲Mysql主从延迟(外赠MySQL异地多活的数据双向复制经验.pdf)

1582
来自专栏杨建荣的学习笔记

由小见大-MySQL脚本部署中的一些策略

在线上环境中部署脚本,可谓是常在河边走,哪有不湿鞋,所以大大小小的案例总结下来,还是会发现一些有趣的地方,这些可以作为操作时的一些参考,仅供参考而已。 第一类...

3256
来自专栏沃趣科技

ASM 翻译系列第二十一弹:ASM Attributes Directory

原作者:Bane Radulovic 译者: 郭旭瑞 审核: 魏兴华 DBGeeK社群联合出品 ASM Attributes Directory A...

3274
来自专栏数据分析

[SQLServer大对象]——FileTable初体验

在我接触FileTable之前,存储文件都是存储文件的链接和扩展名到数据,其实并没有实际的把文件存储到数据库。 FileTable不同于一般的表,他可以存储非结...

3586
来自专栏腾讯云数据库(TencentDB)

MySQL 8.0 版本功能变更介绍

作者介绍:朱强,腾讯云数据库高级工程师,主要负责腾讯云数据库MySQL的开发和运营,曾就职于华为和网宿,在存储、文件系统开发有丰富经验。

1.1K56
来自专栏云计算教程系列

如何使用Symlink更改MySQL数据目录

数据库随着时间的推移而增长,有时会超出文件系统的空间。当它们与操作系统的其余部分位于同一分区时,可能会遇到I/O冲突。RAID,网络块存储和其他设备可以提供冗余...

1586

扫码关注云+社区