精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

dba+開源工具:數據恢復搭把手!MySQL二進制日志解析轉換工具

開發 開發工具
reverse_sql是一個用于解析和轉換MySQL二進制日志(binlog)的工具。它可以將二進制日志文件中記錄的數據庫更改操作(如插入、更新、刪除)轉換為反向的SQL語句,以便進行數據恢復。其運行模式需二進制日志設置為ROW格式。

工具簡介

reverse_sql是一個用于解析和轉換MySQL二進制日志(binlog)的工具。它可以將二進制日志文件中記錄的數據庫更改操作(如插入、更新、刪除)轉換為反向的SQL語句,以便進行數據恢復。其運行模式需二進制日志設置為ROW格式。

該工具的主要功能和特點包括:

1、解析二進制日志:reverse_sql能夠解析MySQL的二進制日志文件,并還原出其中的SQL語句。

2、生成可讀的SQL:生成原始SQL和反向SQL。

3、支持過濾和篩選:可以根據時間范圍、表、DML操作等條件來過濾出具體的誤操作SQL語句。

4、支持多線程并發解析binlog事件。

請注意!reverse_sql只是將二進制日志還原為SQL語句,而不會執行這些SQL語句來修改數據庫。

原理

調用官方(https://python-mysql-replication.readthedocs.io/)庫來實現,通過指定的時間范圍,轉換為timestamp時間戳,將整個時間范圍平均分配給每個線程。

由于BinLogStreamReader并不支持指定時間戳來進行遞增解析,固在每個任務開始之前,使用上一個任務處理過的binlog_file和binlog_pos,這樣后續的線程就可以獲取到上一個線程處理過的binlog文件名和position,然后進行后續的并發處理。

假設開始時間戳start_timestamp是1625558400,線程數量num_threads是4,整個時間范圍被平均分配給每個線程。那么,通過計算可以得到以下結果:

對于第一個線程(i=0),start_time是1625558400。

對于第二個線程(i=1),start_time是1625558400 + time_range。

對于第三個線程(i=2),start_time是1625558400 + 2 * time_range。

對于最后一個線程(i=3),start_time是1625558400 + 3 * time_range。

這樣,每個線程的開始時間都會有所偏移,確保處理的時間范圍沒有重疊,并且覆蓋了整個時間范圍。最后,將結果保存在一個列表里,并對列表做升序排序,取得最終結果。

使用

shell> chmod 755 reverse_sql
shell> ./reverse_sql --help
usage: reverse_sql [-h] [-ot ONLY_TABLES [ONLY_TABLES ...]] [-op ONLY_OPERATION] -H MYSQL_HOST
                   -P MYSQL_PORT -u MYSQL_USER -p MYSQL_PASSWD -d MYSQL_DATABASE
                   [-c MYSQL_CHARSET] --binlog-file BINLOG_FILE [--binlog-pos BINLOG_POS]
                   --start-time ST --end-time ET [--max-workers MAX_WORKERS] [--print]

Binlog數據恢復,生成反向SQL語句。

options:
  -h, --help            show this help message and exit
  -ot ONLY_TABLES [ONLY_TABLES ...], --only-tables ONLY_TABLES [ONLY_TABLES ...]
                        設置要恢復的表,多張表用,逗號分隔
  -op ONLY_OPERATION, --only-operation ONLY_OPERATION
                        設置誤操作時的命令(insert/update/delete)
  -H MYSQL_HOST, --mysql-host MYSQL_HOST
                        MySQL主機名
  -P MYSQL_PORT, --mysql-port MYSQL_PORT
                        MySQL端口號
  -u MYSQL_USER, --mysql-user MYSQL_USER
                        MySQL用戶名
  -p MYSQL_PASSWD, --mysql-passwd MYSQL_PASSWD
                        MySQL密碼
  -d MYSQL_DATABASE, --mysql-database MYSQL_DATABASE
                        MySQL數據庫名
  -c MYSQL_CHARSET, --mysql-charset MYSQL_CHARSET
                        MySQL字符集,默認utf8
  --binlog-file BINLOG_FILE
                        Binlog文件
  --binlog-pos BINLOG_POS
                        Binlog位置,默認4
  --start-time ST       起始時間
  --end-time ET         結束時間
  --max-workers MAX_WORKERS
                        線程數,默認10
  --print               將解析后的SQL輸出到終端
--replace             將update轉換為replace操作

Example usage:
shell> ./reverse_sql -ot table1 -op delete -H 192.168.198.239 -P 3336 -u admin -p hechunyang -d hcy  --binlog-file mysql-bin.000124  --start-time "2023-07-06 10:00:00"  --end-time "2023-07-06 22:00:00" 

當出現誤操作時,只需指定誤操作的時間段,其對應的binlog文件(通常你可以通過show master status得到當前的binlog文件名)以及剛才誤操作的表,和具體的DML命令,比如update或者delete。

工具運行時,首先會進行MySQL的環境檢測(if binlog_format != 'ROW' and binlog_row_image != 'FULL'),如果不同時滿足這兩個條件,程序直接退出。

工具運行后,會在當前目錄下生成一個{db}_{table}_recover.sql文件,保存著原生SQL(原生SQL會加注釋)和反向SQL,如果想將結果輸出到前臺終端,可以指定--print選項。

如果你想把update操作轉換為replace,指定--replace選項即可,同時會在當前目錄下生成一個{db}_{table}_recover_replace.sql文件。

圖片圖片

MySQL最小化用戶權限:


> GRANT REPLICATION SLAVE, REPLICATION CLIENT ON *.* TO 
`yourname`@`%`;

> GRANT SELECT ON `test`.* TO `yourname`@`%`;

恢復

在{db}_{table}_recover.sql文件中找到你剛才誤操作的DML語句,然后在MySQL數據庫中執行逆向工程后的SQL以恢復數據。

如果{db}_{table}_recover.sql文件的內容過多,也可以通過awk命令進行分割,以便更容易進行排查。

shell> awk '/^-- SQL執行時間/{filename = "output" ++count ".sql"; print > filename; next} {print > filename}' test_t1_recover.sql

不支持drop和truncate操作,因為這兩個操作屬于物理性刪除,需要通過歷史備份進行恢復。

注:reverse_sql支持MySQL 5.7/8.0和MariaDB,適用于CentOS 7系統。

2023年7月12日更新 - 分之版本:可實現進度條展示(處理binlog的event數量和耗時時間)。

工具研發者介紹

賀春旸,dbaplus社群金牌專家,凡普金科和愛錢進DBA團隊負責人,《MySQL管理之道:性能調優、高可用與監控》第一&二版、《MySQL運維進階指南》作者,曾任職于中國移動飛信、安卓機鋒網。五次榮獲dbaplus年度MVP,致力于MariaDB、MongoDB等開源技術的研究,主要負責數據庫性能調優、監控和架構設計。

工具下載:https://github.com/hcymysql/reverse_sql/

責任編輯:武曉燕 來源: dbaplus社群
相關推薦

2023-06-27 07:29:30

dba+開源工具Binlog

2023-08-29 07:22:06

MySQL數據工具故障恢復

2010-06-09 13:02:29

MySQL啟用二進制日

2010-10-13 15:45:23

MySQL二進制日志

2023-10-31 07:27:22

開源工具MySQL協議

2022-06-07 09:58:48

Spotify開源音頻文件

2020-05-19 11:46:50

MongoDB圖形開源

2010-01-08 10:49:21

JSON 轉換工具

2018-12-12 14:15:40

MongoDB熱備份工具數據庫

2023-01-28 07:52:49

2018-08-21 10:05:59

MySQLbinlog數據庫

2023-08-11 07:20:04

開源工具項目

2018-10-22 14:37:16

二進制數據存儲

2023-10-17 07:51:37

MySQLQPS優化

2021-01-14 09:40:54

漏洞macOS屬性表文件

2025-05-13 08:10:00

MySQL二進制日志binlog

2020-07-20 07:33:44

Python開發工具

2017-12-21 10:52:52

nginx日志還原

2018-08-31 10:10:55

Linux開源轉換工具

2014-08-06 10:10:52

MariaDB二進制日志
點贊
收藏

51CTO技術棧公眾號

久久综合九色欧美狠狠| 国产91成人video| 久久无码专区国产精品s| 免费不卡av| 久久精品视频网| 亚洲在线第一页| 在线天堂中文字幕| 91精品婷婷色在线观看| 日韩av在线直播| 五月天婷婷亚洲| 国产传媒在线观看| 国产精品久久久久aaaa| 精品一区2区三区| 91肉色超薄丝袜脚交一区二区| 欧美在线黄色| 国产一区二区三区视频免费| 四虎成人免费视频| 日韩成人在线电影| 欧美日韩免费网站| 日韩视频 中文字幕| 成人动漫在线播放| 99国产精品久久久久| 成人免费在线网址| 中文字幕一区二区人妻视频| 国模 一区 二区 三区| 色七七影院综合| 久久精品一区二区免费播放| 伊人久久噜噜噜躁狠狠躁| 日本道色综合久久| 狠狠97人人婷婷五月| 在线网址91| 国产精品福利一区| 日韩av在线一区二区三区| 天堂成人在线观看| 国产伦精品一区二区三区视频青涩| 日本中文字幕不卡免费| 三级黄色在线视频| 激情视频一区二区三区| 欧美成人免费网| www欧美com| 欧美a级片视频| 伊人久久综合97精品| 青青草福利视频| 加勒比久久高清| 日韩免费看网站| 性鲍视频在线观看| 韩国三级大全久久网站| 91精品欧美综合在线观看最新| 成人黄色一区二区| 欧美日韩国产网站| 欧洲国内综合视频| 中文字幕第80页| 日韩高清在线| 欧美午夜一区二区三区免费大片| 激情网站五月天| 黄瓜视频成人app免费| 一本到三区不卡视频| 99re在线视频免费观看| 成人勉费视频| 在线免费精品视频| 99re精彩视频| 精品亚洲二区| 精品福利一区二区三区免费视频| 师生出轨h灌满了1v1| 豆花视频一区二区| 亚洲精品综合久久中文字幕| 人妻大战黑人白浆狂泄| 日韩免费一区| 操91在线视频| 免费观看一级视频| 性感少妇一区| 国产精品久久久久77777| 中文字幕日韩第一页| 久久精品国产在热久久| 91在线免费看网站| 欧美一级淫片免费视频魅影视频| 91毛片在线观看| 日韩欧美99| av免费在线观看网站| 亚洲一区二区中文在线| 激情六月丁香婷婷| 婷婷激情成人| 亚洲黄页网在线观看| 亚洲精品国产91| 91精品婷婷色在线观看| 91国内精品久久| 性色av一区二区三区四区| 韩国三级在线一区| 精品国产乱码久久久久久郑州公司 | 国产精品女视频| 国产美女免费视频| 26uuu欧美| 在线观看一区二区三区三州| 91九色国产在线播放| 在线视频观看一区| 中文字幕1区2区| 欧美一区二区三| 欧美激情免费观看| 在线观看国产区| 国产成人8x视频一区二区| 欧美日韩电影一区二区| 成人在线视频亚洲| 一本到三区不卡视频| 免费看的av网站| 免费看成人吃奶视频在线| 久久久av一区| 天天干天天操天天操| 国产iv一区二区三区| 亚洲精品久久久久久一区二区| 精品一性一色一乱农村| 欧美日本国产视频| 在线不卡av电影| 亚洲视频日本| 成人乱人伦精品视频在线观看| 欧美精品久久久久久久久久丰满| 亚洲女同女同女同女同女同69| 成年人黄色片视频| 老牛影视av一区二区在线观看| 按摩亚洲人久久| 无码人妻精品一区二区三区9厂| 国产福利精品导航| 一区二区三区四区五区精品| 伊人久久国产| 亚洲精品电影网在线观看| 九九视频免费在线观看| 久久福利资源站| 日韩一区免费观看| 亚洲欧洲美洲av| 亚洲国产精彩中文乱码av在线播放| 性欧美疯狂猛交69hd| 日韩福利电影在线观看| 欧美日韩在线观看一区二区三区| av电影在线免费| 精品日韩在线观看| 久久国产一级片| 国产成a人亚洲精| 亚洲中文字幕无码一区二区三区| 九九热这里有精品| 中文字幕亚洲综合| 中文字幕有码视频| 中文字幕一区二区三区不卡| 九九热在线免费| 成人在线丰满少妇av| 国产精品日韩在线播放| 波多野结衣在线网站| 欧美色图天堂网| 国产精品久久久视频| 男女男精品网站| 亚洲视频导航| 天天综合91| 九九精品在线播放| 亚洲黄色在线免费观看| 亚洲国产中文字幕在线视频综合| wwwxx日本| 午夜亚洲伦理| 婷婷久久五月天| 亚洲二区av| 欧美国产视频日韩| 五月婷婷在线播放| 在线观看日韩毛片| 在线免费看av网站| 成人精品免费网站| 各处沟厕大尺度偷拍女厕嘘嘘| 美女久久99 | 精品国产18久久久久久二百| 久久国产精品久久久久久久久久| 国产成人av免费看| 精品久久久久久中文字幕一区奶水 | 成人性生交大片| 成人一级片网站| 日韩欧美高清在线播放| 亚洲mm色国产网站| 韩国精品一区| 一区二区三区四区在线观看视频| 国产女18毛片多18精品| 无吗不卡中文字幕| 亚洲一级片在线播放| 国产乱码字幕精品高清av| 日本www在线视频| 日韩精品一区二区久久| 亚洲自拍偷拍视频| 中文在线免费视频| 久久久91精品国产| 天堂中文资源在线| 欧美日本在线播放| www..com国产| 亚洲欧洲成人精品av97| 白嫩情侣偷拍呻吟刺激| 蜜桃av一区二区| www..com日韩| 91一区二区| 精品国产乱码久久久久久108| 成人午夜sm精品久久久久久久| 欧美俄罗斯性视频| av二区在线| 亚洲福利视频专区| 91亚洲精品国偷拍自产在线观看| 亚洲电影一区二区三区| 蜜桃视频最新网址| xfplay精品久久| 亚洲麻豆一区二区三区| 久久99精品网久久| www.国产区| 在线视频观看日韩| 天堂v在线视频| 国产成人1区| 国产精品免费视频一区二区| 亚洲tv在线| 日韩免费在线播放| ririsao久久精品一区| 久久精品国产一区二区三区| 黄色片视频在线观看| 亚洲国产成人精品电影| 99精品久久久久久中文字幕 | 99国产精品久久久久99打野战| 色综合久久久久综合| 国产无遮挡又黄又爽又色| 国产精品国产自产拍在线| 粉嫩av蜜桃av蜜臀av| 成人av动漫在线| 日韩大尺度视频| 久久精品99久久久| 青青草av网站| 老司机午夜精品视频| 欧美日韩成人免费视频| 国内自拍视频一区二区三区| 黄频视频在线观看| 日韩一区电影| 图片区小说区区亚洲五月| 日日天天久久| 国产一区喷水| h视频久久久| 成人做爰66片免费看网站| 欧美视频二区欧美影视| 国产在线视频91| 亚洲国产伊人| 亚洲一区中文字幕| 成人污污www网站免费丝瓜| 国产欧美精品一区二区三区-老狼| 欧亚一区二区| 国产精品一区二区三| 久久精品黄色| 91在线国产电影| 亚洲精品高潮| 国产精品二区在线| 国产精品丝袜在线播放| 国产欧美日韩综合精品二区| 超碰在线亚洲| 懂色中文一区二区三区在线视频 | 精品精品国产高清一毛片一天堂| www.久久久久久| 欧美大胆人体bbbb| 你懂的网站在线| 精品亚洲aⅴ在线观看| 激情小视频在线| 色多多国产成人永久免费网站 | 国产视频网站在线| 一区二区三区视频观看| 在线免费看黄| 欧美精品在线免费| 日韩深夜视频| 国产精品私拍pans大尺度在线 | 日韩黄色免费观看| 亚洲一区二区三区影院| 99热在线观看免费精品| 在线精品视频免费观看| 亚洲天堂网在线观看视频| 91精品国产综合久久精品麻豆 | 亚洲美女色播| av免费观看久久| 天堂在线精品| 中文字幕一区二区三区在线乱码| 欧美区国产区| 999香蕉视频| 国产乱码精品1区2区3区| 国产日韩视频一区| 国产蜜臀av在线一区二区三区| 国产在线免费看| 亚洲成人自拍偷拍| 人妻中文字幕一区二区三区| 91精品国产欧美一区二区成人| 四虎永久在线观看| 日韩中文字幕在线视频| av日韩中文| 成人亚洲欧美一区二区三区| av成人资源网| 一级日韩一区在线观看| 亚洲高清成人| 中文字幕资源在线观看| 99综合电影在线视频| 中国一级片在线观看| 亚洲成av人片一区二区| 一区二区三区免费观看视频| 亚洲第一页中文字幕| 欧美69xxx| 日韩av成人在线| 亚洲高清在线一区| 性欧美videosex高清少妇| 国产一区日韩一区| www.com污| 久久综合九色欧美综合狠狠| a一级免费视频| 91成人国产精品| 亚洲精品无遮挡| 精品国产欧美一区二区五十路 | 色中色一区二区| 丰满人妻一区二区三区免费| 丝袜美腿亚洲一区二区| 超碰一区二区| 精品乱码一区| 国产在线不卡| 两性午夜免费视频| 国产精品污污网站在线观看| 日本中文在线播放| 日韩视频一区二区三区在线播放 | 日本视频久久久| 懂色av一区二区| 人人妻人人澡人人爽欧美一区| 美女性感视频久久| av电影网站在线观看| 欧美日韩国内自拍| 农村少妇久久久久久久| 欧美猛交免费看| 欧美影院视频| 好吊色视频988gao在线观看| 久久99精品久久久| 特黄一区二区三区| 欧美在线观看一区二区| 国产片在线观看| 国产精品电影观看| 在线成人动漫av| 少妇高清精品毛片在线视频| eeuss影院一区二区三区| 国产一级一片免费播放放a| 91精品国产综合久久久蜜臀粉嫩 | 国产区亚洲区欧美区| 欧美精品第一区| 久久人妻精品白浆国产| 久久久电影一区二区三区| 一级成人黄色片| 亚洲欧美国产制服动漫| 北岛玲heyzo一区二区| 欧美日韩精品久久久免费观看| 久久久噜噜噜| 亚洲高潮女人毛茸茸| 欧美日韩电影一区| 黄色片网站在线观看| 亚洲综合社区网| 亚洲婷婷免费| 午夜一区二区三区免费| 日韩欧美亚洲成人| 成人综合影院| 成人免费在线视频网址| 欧美日韩99| 97人妻精品一区二区三区免| 日韩欧美在线视频日韩欧美在线视频| 奇米影视888狠狠狠777不卡| 国产精品av在线| 99久久久国产精品美女| 熟妇女人妻丰满少妇中文字幕| 亚洲国产成人tv| 色鬼7777久久| 国产精品久久久久久久一区探花| 青青草综合网| 台湾佬美性中文| 欧美日韩免费在线观看| 成人精品一区二区三区校园激情| 国产美女被下药99| 欧美精品一卡| 欧美老熟妇乱大交xxxxx| 在线看不卡av| 日本动漫理论片在线观看网站| 黑人中文字幕一区二区三区| 日韩av一区二区三区| 91精品少妇一区二区三区蜜桃臀| 日韩三级中文字幕| 亚洲性受xxx喷奶水| youjizz.com亚洲| 99久久婷婷国产综合精品| 最新国产中文字幕| 欧美猛交免费看| 不卡视频在线| 亚洲av无码一区东京热久久| 欧美性猛片aaaaaaa做受| jizzjizz亚洲| 欧美美乳视频网站在线观看| 精品一区二区免费看| 日本三级理论片| 中文字幕日韩高清| 另类春色校园亚洲| 亚洲综合欧美在线| 激情av一区二区| 国产激情在线| 日韩精品久久一区| 成人免费观看av| 国产一区二区三区黄片| 欧美一级电影久久| 欧美破处大片在线视频| 久久久精品成人| 亚洲精品国产福利|