数据和云 关注
手机版

如何利用 Myflash 解析 binlog ?

  1. 云栖社区>
  2. 数据和云>
  3. 博客>
  4. 正文

如何利用 Myflash 解析 binlog ?

技术小能手 2018-04-26 10:23:30 浏览7574 评论0

摘要: 1) 首先需要准备好 Myflash 测试环境 大家可以去这里下载源程序:https://github.com/Meituan-Dianping/MyFlash 这里的测试环境是 Redhat Linux 6.5,直接解压 myflash 无法运行,发现 glibc 版本不匹配,需要 2.14 版本。

1) 首先需要准备好 Myflash 测试环境

大家可以去这里下载源程序:https://github.com/Meituan-Dianping/MyFlash

这里的测试环境是 Redhat Linux 6.5,直接解压 myflash 无法运行,发现 glibc 版本不匹配,需要 2.14 版本。因此首先需要编译新版本的 glibc。

–下载 glibc 2.14

---下载lib包

# wget http://ftp.gnu.org/gnu/glibc/glibc-2.14.tar.gz

# wget http://ftp.gnu.org/gnu/glibc/glibc-ports-2.14.tar.gz

# tar -xvf glibc-2.14.tar.gz

# tar -xvf glibc-ports-2.14.tar.gz

# mv glibc-ports-2.14 glibc-2.14/ports

# mkdir glibc-build-2.14

# cd glibc-build-2.14/

–编译

# ../glibc-2.14/configure --prefix=/usr --disable-profile --enable-add-ons --with-headers=/usr/include --with-binutils=/usr/bin

# make

–拷贝 libc.so.6 到 /lib64

[root@killdb glibc-build-2.14]# cp libc.so.6 /lib64/libc-2.14.so

–删除原来的 libc

[root@killdb lib64]# rm -rf /lib64/libc.so.6

rm: error while loading shared libraries: libc.so.6: cannot open shared object file: No such file or directory

[root@killdb lib64]# export LD_PRELOAD=/lib64/libc-2.14.so

[root@killdb lib64]# rm -rf /lib64/libc.so.6

[root@killdb lib64]# ln -s /lib64/libc-2.14.so /lib64/libc.so.6

–make install

# make install

–确认是否 OK

904e03b470e2db1803ea1532e7b102ce922a9e01

可以看到已经可以了,支持最新的 GLIBC_2.14 了。下面开始测试 myflash。

2) 如下是针对 Myflash 的简单测试过程

–创建测试表

mysql> CREATE TABLE `Test` (

-> `ID` int(11) NOT NULL AUTO_INCREMENT,

-> `NAME` varchar(50) NOT NULL,

-> PRIMARY KEY (`ID`)

-> ) AUTO_INCREMENT=1000

-> ;

–创建测试存储过程模拟 10 万条测试数据

mysql> delimiter $$

mysql> create procedure pro_test()

-> begin

-> declare id int;

-> set id = 100000;

-> while id>0 do

-> insert into Test(name) values ('www.killdb.com');

-> set id = id-1;

-> end while;

-> end $$

Query OK, 0 rows affected (0.00 sec)


mysql> delimiter ;

mysql> call pro_test();

Query OK, 1 row affected (44.21 sec)

–模拟删除 5 万条数据

mysql> delete from Test limit 50000;

Query OK, 50001 rows affected (0.54 sec)


mysql> select count(1) from Test;

+----------+

| count(1) |

+----------+

| 50001 |

+----------+

1 row in set (0.01 sec)


mysql>

–利用 Myflash 解析 binlog

这里简单的修改了一个小脚本,实现了半自动化。

[root@killdb binary]# ./flashback.sh

[root@killdb binary]# cat flashback.sh

#!/bin/bash


file_path=/root/myflash/binary/

cd /root/myflash/binary

./flashback --databaseNames enmotech --tableNames Test --sqlTypes delete --binlogFileNames=/opt/mysql/mysql-bin.000003

./flashback --maxSplitSize=15 --binlogFileNames=binlog_output_base.flashback


arr=`find ${file_path} -name "binlog_output_base.0*"|sort -n`


for i in ${arr}

do

mysqlbinlog ${i} | mysql -S /opt/mysql/mysql.sock

done

–验证数据

mysql> select count(1) from Test;

+----------+

| count(1) |

+----------+

| 100001 |

+----------+

1 row in set (0.02 sec)

可以看到数据很容易就恢复出来了,效率非常高。比 binsql2sql 要高很多。整个恢复过程大概 1~2 秒。不仅是 delete,实际对于 insert 和 update 的 DML 操作,都是支持的。


原文发布时间为:2018-04-25

本文作者:李真旭

本文来自云栖社区合作伙伴“数据和云”,了解相关信息可以关注“数据和云”。

【云栖快讯】你想见的Java技术专家都在这了,向大佬提问,有问题必答  详情请点击

网友评论

技术小能手
文章7218篇 | 关注1722
关注
为企业和开发者提供稳定、安全、智能的把网站域名或应用资源转换为计算机用于互连的数字 IP地址... 查看详情
移动测试(Mobile Testing)是为广大企业客户和移动开发者提供真机测试服务的云平台... 查看详情
HTTPDNS是面向移动开发者推出的一款域名解析产品,具有域名防劫持、精准调度的特性。 查看详情
为您提供简单高效、处理能力可弹性伸缩的计算服务,帮助您快速构建更稳定、安全的应用,提升运维效... 查看详情
阿里云总监课正式启航

阿里云总监课正式启航