日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

如何利用 Myflash 解析 binlog ?

發布時間:2025/3/8 编程问答 30 豆豆
生活随笔 收集整理的這篇文章主要介紹了 如何利用 Myflash 解析 binlog ? 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

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.6rm: 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


可以看到已經可以了,支持最新的 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/bashfile_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.flashbackarr=`find ${file_path} -name "binlog_output_base.0*"|sort -n`for i in ${arr}domysqlbinlog ${i} | mysql -S /opt/mysql/mysql.sockdone

–驗證數據

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

本文作者:李真旭

本文來自云棲社區合作伙伴“數據和云”,了解相關信息可以關注“數據和云”。

總結

以上是生活随笔為你收集整理的如何利用 Myflash 解析 binlog ?的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。