当前位置: 首页 >> 技术文章 >> 如何利用 Myflash 解析 binlog ?
如何利用 Myflash 解析 binlog ?
发布时间:2018-04-26 发布人:李真旭 1017

新美大在 binlog2sql 的基础只是开源了一款新的小工具叫 Myflash;用于解析binlog 实现快速数据恢复,类似 Oracle 中的 Flashback 功能,不过目前仅支持MySQL 5.6、5.7版本(MariaDB 10 已经引入了 Flashback 功能)。在这里进行了简单测试,以后恢复 DML 误操作就更简单一些了。


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