Mysql闪回技术之 binlog2sql
1.下载
https://github.com/danfengcao/binlog2sql
Search: python-pip
pip 是一个Python包管理工具,主要是用于安装 PyPI 上的软件包。
2. 安装
1
2
3
4
5
6
7
|
# yum install python-setuptools -y # rpm -ivh python-pip-7.1.0-1.el6.noarch.rpm --rpmfind.net 下载上传安装 # pip install PyMySQL # pip install -r requirments.txt # pwd /usr/local/binlog2sql-master/binlog2sql-master # less README.md --这个必须要看个十遍,八遍的才行 |
3. 测试用例
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
|
(root@localhost) [kk]> create database roidba; Query OK, 1 row affected (0.00 sec) (root@localhost) [kk]> use roidba Database changed (root@localhost) [roidba]> create table roidba ( id int,name varchar(10)); Query OK, 0 rows affected (0.15 sec) (root@localhost) [roidba]> insert into roidba values(1, 'mysql' ); Query OK, 1 row affected (0.00 sec) (root@localhost) [roidba]> insert into roidba values(2, 'oracle' ); Query OK, 1 row affected (0.00 sec) (root@localhost) [roidba]> insert into roidba values(3, 'mariadb' ); Query OK, 1 row affected (0.00 sec) (root@localhost) [roidba]> delete from roidba; Query OK, 3 rows affected (0.01 sec) (root@localhost) [roidba]> select * from roidba; Empty set (0.00 sec) |
4. 创建闪回用户
1
2
3
4
5
|
(root@localhost) [roidba]> GRANT SELECT,REPLICATION SLAVE,REPLICATION CLIENT ON *.* TO flashback@ '%' identified by 'flashback' ; Query OK, 0 rows affected (0.04 sec) (root@localhost) [roidba]> flush privileges; Query OK, 0 rows affected (0.05 sec) |
5. 闪回的要求
1
2
3
4
5
6
7
8
9
10
|
1)知道大概的时间点2017-01-12 18:00 ~ 2017-01-12 18:00 2)知道binlog信息 (root@localhost) [roidba]> show binary logs; +------------------+----------------+ | Log_name | File_size | +------------------+----------------+ | mysql-bin.000001 |3828 | | mysql-bin.000002 | 238 | | mysql-bin.000003 |1231 | +------------------+---------------+ |
6. 解析
1
2
3
4
5
6
7
8
9
10
11
12
|
--binlog中解析的sql [root@mysql-121 binlog2sql-master] # python binlog2sql/binlog2sql.py -h192.168.80.132 -P3306 -uflashback -pflashback -droidba -troidba --start-file='mysql-bin.000003' --start-datetime='2017-01-12 18:00:00' --stop-datetime='2017-01-12 18:30:00' INSERT INTO `roidba`.`roidba`(` id `, `name`) VALUES (1, 'mysql' ); #start 239 end 413 time 2017-01-12 18:10:54 INSERT INTO `roidba`.`roidba`(` id `, `name`) VALUES (2, 'oracle' ); #start 492 end 667 time 2017-01-12 18:11:00 INSERT INTO `roidba`.`roidba`(` id `, `name`) VALUES (3, 'mariadb' ); #start 746 end 922 time 2017-01-12 18:11:08 DELETE FROM `roidba`.`roidba` WHERE ` id `=1 AND `name`= 'mysql' LIMIT 1; #start 1001 end 1200 time 2017-01-12 18:11:14 DELETE FROM `roidba`.`roidba` WHERE ` id `=2 AND `name`= 'oracle' LIMIT 1; #start 1001 end 1200 time 2017-01-12 18:11:14 DELETE FROM `roidba`.`roidba` WHERE ` id `=3 AND `name`= 'mariadb' LIMIT 1; #start 1001 end 1200 time 2017-01-12 18:11:14 USE roidba; GRANT SELECT, REPLICATION SLAVE, REPLICATION CLIENT ON *.* TO 'flashback' @ '%' IDENTIFIED BY PASSWORD '*6DE874C277DDA35061BD526FB38B6A3C8B3A9254' ; USE roidba; flush privileges; |
7. 闪回
1
2
3
4
5
6
7
8
|
--闪回sql # python binlog2sql/binlog2sql.py -h192.168.80.132 -P3306 -uflashback -p'flashback' -droidba -troidba --start-file='mysql-bin.000003' --start-position=1001 --stop-position=1200 -B > rollback.sql [root@mysql-121 binlog2sql-master] # less rollback.sql INSERT INTO `roidba`.`roidba`(` id `, `name`) VALUES (3, 'mariadb' ); #start 1001 end 1200 time 2017-01-12 18:11:14 INSERT INTO `roidba`.`roidba`(` id `, `name`) VALUES (2, 'oracle' ); #start 1001 end 1200 time 2017-01-12 18:11:14 INSERT INTO `roidba`.`roidba`(` id `, `name`) VALUES (1, 'mysql' ); #start 1001 end 1200 time 2017-01-12 18:11:14 --开始回滚 [root@mysql-121 binlog2sql-master] # mysql -ubackup -pbackup -h192.168.80.132 <./rollback.sql --具有插入权限才可以 |
8.验证
自己多测试,多动手,看别人做很简单,其实真的自己上手就不一定了,少说多做,少扯淡。
Mysql闪回技术之 binlog2sql的更多相关文章
- (4.11)mysql备份还原——mysql闪回技术(基于binlog)
0.闪回技术与工具简介 mysql闪回工具比较流行三大类: [0.1]官方的mysqlbinlog:支持数据库在线/离线,用脚本处理binlog的输出,转化成对应SQL再执行.通用性不好,对正则.se ...
- MySQL 闪回工具之 binlog2sql
生产上误删数据.误改数据的现象也是时常发生的现象,作为 DBA 这时候就需要出来补锅了,最开始的做法是恢复备份,然后从中找到需要的数据再进行修复,但是这个时间太长了,对于大表少数数据的修复来讲,动作太 ...
- Mysql闪回工具之binlog2sql的原理及其使用
生产上误删数据.误改数据的现象也是时常发生的现象,作为运维这时候就需要出来补锅了,最开始的做法是恢复备份,然后从中找到需要的数据再进行修复,但是这个时间太长了,对于大表少数数据的修复来讲,动作太大,成 ...
- MySQL闪回工具之binlog2sql
一.binlog2sql 1.1 安装binlog2sql git clone https://github.com/danfengcao/binlog2sql.git && cd b ...
- mysql 闪回原理
利用MySQL闪回技术恢复误删除误更改的数据 笔者相信很多人都遇到过忘带where条件或者where条件漏写了一个和写错了的情况,结果执行了delete/update后把整张表的数据都给改了.传统的解 ...
- Mysql 之闪回技术 binlog2sql
1.下载 https://github.com/danfengcao/binlog2sql http://rpmfind.net Search: python-pip pip 是一个Python包管理 ...
- MySQL闪回工具之myflash 和 binlog2sql
MySQL闪回工具之:binlog2sql https://github.com/danfengcao/binlog2sql MYSQL Binglog分析利器:binlog2sql使用详解 :h ...
- mysql闪回工具--binlog2sql实践
DBA或开发人员,有时会误删或者误更新数据,如果是线上环境并且影响较大,就需要能快速回滚.传统恢复方法是利用备份重搭实例,再应用去除错误sql后的binlog来恢复数据.此法费时费力,甚至需要停机维护 ...
- MySQL闪回原理与实战
本文将介绍闪回原理,给出笔者的实战经验,并对现存的闪回工具作比较. DBA或开发人员,有时会误删或者误更新数据,如果是线上环境并且影响较大,就需要能快速回滚.传统恢复方法是利用备份重搭实例,再应用去除 ...
随机推荐
- [Android UI] Service里面启动Activity和Alertdialog
启动Activity源码:(记得要加上Intent.FLAG_ACTIVITY_NEW_TASK) Intent intent = new Intent(); intent.setFlags(Inte ...
- 从配置websocket理解nginx
原文地址:http://www.niu12.com/article/2 今天由于写了一个简单的基于h5 websoceket的聊天室,再本地都是好好了. 但是上到服务器后就发现无法行的通, 查 ...
- 项目管理利器——Maven阅读目录
阅读目录 一.Maven介绍及环境搭建 二.构建Maven版的Hello World 三.Maven常见构建命令 四.自动创建目录骨架 五.Maven中的坐标和仓库 六.在eclipse中安装Mave ...
- sqlserver用于统计表索引情况
/*eg: --调用该过程实例 --1 创建临时表 IF OBJECT_ID('tempdb..#index_sql_text') IS NOT NULL DROP TABLE #index_sql_ ...
- gulp的入门浅析
阅读目录 介绍gulp 安装gulp gulpfile.js 运行gulp 介绍gulp的api 介绍gulp gulp是基于Nodejs的自动任务运行器, 她能自动化地完成 javascript/c ...
- [Android 4.4.4] 泛泰A850 三版通刷 Mokee4.4.4 KTU84P 20140626 RC2.2 by syhost
RC2.1版地址: http://blog.csdn.net/syhost/article/details/34051923 2014.06.26 RC2.2 更新内容: 1 修复相机录像无声的bug ...
- OpenStack制作Windows 2008 KVM镜像
1.下载驱动程序 [root@linux-node1 ~]# cd /usr/local/src [root@linux-node1 src]# wget https://launchpad.net/ ...
- Linux、CentOS系统下调整home和根分区大小
1.首先查看磁盘使用情况 [root@localhost ~]# df -h 文件系统 容量 已用 可用 已用% 挂载点 Filesystem Size Used Avail Use% Mounted ...
- js同比例缩放图片
function DrawImage(ImgD, FitWidth, FitHeight) { var image = new Image(); image.src = ImgD.src; if (i ...
- cadvisor详解
一. cadvisor和k8s的耦合 cadvisor是一个谷歌开发的容器监控工具,它被内嵌到k8s中作为k8s的监控组件.现在将k8s中的cadvisor实现分析一下. k8s中和cadvisor的 ...