MYSQL工具之binlog2sql闪回操作
文档结构:

在生产环境中如果遇到误删,改错数据的情况,利用mysql闪回工具binlog2sql,可以实现数据的快速回滚,从binlog中提取SQL,并能生成回滚SQL语句。Binlog以event作为单位记录数据库变更的数据信息,闪回就是可以重现这些变化数据信息之前的操作。也就是说,对于insert操作,会生成相反的update语句。这块工具只能使用在binlog格式为row模式下,且只支持DML语句不支持DDL语句。
binlog2sql下载地址:https://github.com/danfengcao/binlog2sql
依赖包链接:
https://pan.baidu.com/s/15dDeGufVWOgVrfATGWBzaA 密码:gnz8
setup-tools下载地址:
https://pypi.python.org/packages/2.7/s/setuptools/setuptools-0.6c11-py2.7.egg
python2.7下载地址:https://www.python.org/downloads/
实验环境:
数据库版本:
mysql5.7.20
操作系统:red-hat 6.7
python:2.7.15
1、环境准备
1、安装python2.7
1.1首先安装python2.7(6.x默认是安装2.6)
安装参考:http://www.cnblogs.com/balaamwe/p/3480430.html
[root@mysql5 binlog2sql-master]# rpm -qa|grep make
make-3.81-20.el6.x86_64
automake-1.11.1-4.el6.noarch
cmake-2.8.12.2-4.el6.x86_64
如果没有安装make工具
yum -y install gcc automake autoconf libtool make
查看是否安装zlib库
rpm -qa|grep zlib
zlib-1.2.3-29.el6.x86_64
zlib-devel-1.2.3-29.el6.x86_64
安装zlib
yum install zlib-devel
检查是否安装ssl 库
[root@mysql5 binlog2sql-master]# rpm -qa|grep openssl
openssl-1.0.1e-42.el6.x86_64
openssl-devel-1.0.1e-42.el6.x86_64
安装openssl
yum install openssl*
安装bzip2依赖库
yum install -y bzip2*
2. 编译安装python2.7.15
cp /soft/Python-2.7.15.tgz /usr/src/
cd /usr/src/
tar -zxvf Python-2.7.15.tgz
vi /usr/src/Python-2.7.15/Modules/Setup.dist
找到
#SSL=/usr/local/ssl
#_ssl _ssl.c \
# -DUSE_SSL -I$(SSL)/include -I$(SSL)/include/openssl \
# -L$(SSL)/lib -lssl -lcrypto
......
#zlib zlibmodule.c -I$(prefix)/include -L$(exec_prefix)/lib -lz
把注释去掉
编译
cd /usr/src/Python-2.7.15
./configure
--prefix=/usr/local/python2.7
make all
make install
make clean
make distclean
(一句一句粘贴)

建立python2.7 软链
mv /usr/bin/python
/usr/bin/python.bak
ln -s
/usr/local/python2.7/bin/python2.7 /usr/bin/python2.7
ln -s
/usr/bin/python2.7 /usr/bin/python

2、安装setup-tools
chmod 775 setuptools-0.6c11-py2.7.egg
sh setuptools-0.6c11-py2.7.egg
3、安装依赖包
(1)PyMySQL-0.8.0安装
tar -zxvf
PyMySQL-0.8.0.tar.gz
cd PyMySQL-0.8.0
python setup.py install

(2)wheel-0.31.0安装
tar -xzvf wheel-0.31.0.tar.gz
cd wheel-0.31.0
python setup.py install

(3)python-mysql-replication安装
unzip python-mysql-replication-master.zip
cd python-mysql-replication-master
python setup.py install

(4)通过pip安装相应的依赖包
tar -xzvf pip-10.0.1.tar.gz
cd pip-10.0.1
python setup.py install

解压binlog2sql软件:
unzip binlog2sql-master.zip
cd
/soft/binlog2sql-master
pip install -r
requirements.txt(前面包都安装成功后,这句就可以不用了)

2、恢复演练
1、查看参数使用
cd
/soft/binlog2sql-master/binlog2sql/
python
binlog2sql.py --help

值得注意的就是--start-datetime,--stop-datetime格式为datetime即%Y-%m-%d %H:%M:%S。
2、闪回要求
1、mysql 服务是开启,离线无法进行binlog。
2、binlog_format 必须是ROW格式。
3、DDL语句无法做到闪回,只能解析DML语句。
3、DML语句闪回测试
删除test库下a1表的前2000行(共10000行)

delete from a1
limit 2000;(drop table 是不能够闪回的)
select count(*)
from a1;

a)
test库创建闪回用户
grant
select,replication slave,replication client on *.* to 'flash'@'%' identified by
'flash';

查看当前binlog

当前binlog文件是mysql-binlog.000008,预估一下刚刚操作时间(由于测试机上时间不准,未带时间)。
cd
/soft/binlog2sql-master/binlog2sql/
python
binlog2sql.py -h127.0.0.1 -P3307 -uflash -pflash -dtest -ta1
--start-file='mysql-binlog.000008'
查看生成的恢复语句。
已下仅为一部分

可以看得SQL位置是在259到10446之间,进行过滤,生成回滚SQL。
python
binlog2sql.py -h127.0.0.1 -P3307 -uflash -pflash -dtest -ta1
--start-file='mysql-binlog.000008' --start-position=259 --stop-position=10446
-B >> flashback.sql

最后应用回滚SQL语句:
source
/soft/binlog2sql-master/binlog2sql/flashback.sql


测试成功!
MYSQL工具之binlog2sql闪回操作的更多相关文章
- binlog2sql闪回工具的使用
binlog2sql闪回工具的使用 一.下载安装依赖的python yum install openssl-devel bzip2-devel expat-devel gdbm-devel readl ...
- MySQL模拟Oralce闪回操作
在前面的文章中我们介绍了MySQL误操作后数据恢复(update,delete忘加where条件),大概操作是通过sed命令把binlog中相关SQL误操作给逆向回来,然后导入SQL文件来恢复错误操作 ...
- PLSQL_闪回操作4_Flashback Drop
2014-06-25 Created By BaoXinjian
- PLSQL_闪回操作1_Flashback Query
2014-07-02 Created By BaoXinjian
- Oracle闪回操作
Oracle闪回操作 1. 记录当前时间或SCN 在数据库变动前记录时间或SCN SQL> select to_char(sysdate,'YYYY-MM-DD HH24:mi:ss') fr ...
- MySQL的binlog2sql闪回
从MySQL binlog解析出你要的SQL.根据不同选项,你可以得到原始SQL.回滚SQL.去除主键的INSERT SQL等. 用途=========== * 数据快速回滚(闪回)* 主从切换后新m ...
- binlog2sql闪回恢复数据
用途: .数据快速回滚 .从binlog生成标准sql 使用限制: .必须设置binlog_format=ROW .binlog_row_image=full,该参数默认为FULL .恢复用户拥有的最 ...
- PLSQL_闪回操作6_Flashback Database
2014-12-09 Created By BaoXinjian
- PLSQL_闪回操作5_Flashback Table
2014-12-09 Created By BaoXinjian
随机推荐
- C# 不卡屏延时方法,延迟系统时间,但系统又能同时能执行其它任务
//延迟系统时间,但系统又能同时能执行其它任务,不卡屏延时方法 public static void Delay(int milliSecond) { int start = Environment. ...
- VC维与DNN的Boundary
原文链接:解读机器学习基础概念:VC维来去 作者:vincentyao 目录: 说说历史 Hoeffding不等式 Connection to Learning 学习可行的两个核心条件 Effecti ...
- 多开 MFC线程
序言:我才编程几年啊!就要处理多线程.对于只写函数的我,这难度简直了!不过MFC的多线程,貌似比较简单,还能处理的了. (1).开MFC多个线程 在视频采集的过程中,如果不使用媒体计数器,会造成主线程 ...
- [Intermediate Algorithm] - Arguments Optional
题目 创建一个计算两个参数之和的 function.如果只有一个参数,则返回一个 function,该 function 请求一个参数然后返回求和的结果. 例如,add(2, 3) 应该返回 5,而 ...
- eslint推荐编码规范和airbnb推荐编码规范
Eslint规范 for 循环禁止使用无限循环(这个非默认推荐) // bad for (var i = 0; i < 10; i--) { } for (var i = 10; i >= ...
- vue-router在同一个路由下切换,取不到变化的路由参数
最近用vue写项目的时候碰到一个问题,在同一个页面下跳转,路由地址不变,路由参数有变化,一开始只是在data里取路由的参数,发现根本取不到变化的路由参数. 例如:订单列表也跳转详情页,跳转方法如下 & ...
- PS通道的界面颜色设置
编辑--首选项---界面--界面---选项---(勾选)以彩色显示通道(彩色显示)或者不勾选(为黑白色显示)
- Python爬虫:HTTP协议、Requests库(爬虫学习第一天)
HTTP协议: HTTP(Hypertext Transfer Protocol):即超文本传输协议.URL是通过HTTP协议存取资源的Internet路径,一个URL对应一个数据资源. HTTP协议 ...
- [系统资源攻略]IO第二篇
IO 磁盘通常是计算机最慢的子系统,也是最容易出现性能瓶颈的地方,因为磁盘离 CPU 距离最远而且 CPU 访问磁盘要涉及到机械操作,比如转轴.寻轨等.访问硬盘和访问内存之间的速度差别是以数量级来计算 ...
- LeetCode SQL题目(第一弹)
LeetCode SQL题目 注意:Leetcode上的SQL编程题都提供了数据表的架构程序,只需要将它贴入本地数据库即可调试自己编写的程序 不管是MS-SQL Server还是MySQL都需要登陆才 ...