精品欧美一区二区三区在线观看 _久久久久国色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技術棧公眾號

亚洲黄色毛片| 国产午夜精品一区理论片| 一级毛片免费高清中文字幕久久网| 欧美狂野另类xxxxoooo| 日本老太婆做爰视频| 欧美 日韩 人妻 高清 中文| 亚洲女人av| 日韩有码视频在线| 你懂得在线视频| 88xx成人免费观看视频库| 亚洲品质自拍视频| 欧美日韩国产三区| 性色av蜜臀av| 日韩电影免费一区| 欧美极品在线视频| 国产18无套直看片| 欧美激情15p| 制服丝袜在线91| 无码人妻丰满熟妇区毛片| dj大片免费在线观看| 久久老女人爱爱| 成人在线观看av| 97超碰人人草| 视频在线在亚洲| 久久久最新网址| 国产成人无码aa精品一区| 欧美电影在线观看免费| 欧洲国产伦久久久久久久| 欧美韩日一区二区三区| 日韩美女免费视频| 国产亚洲精品久久777777| 在线观看黄色网| 88xx成人免费观看视频库| 亚洲激情图片一区| 一级做a爰片久久| 国产最新视频在线| 26uuu国产电影一区二区| 99久久伊人精品影院| 国产伦精品一区二区三区免.费| 丝袜美腿成人在线| 欧洲日韩成人av| 欧美特黄aaaaaa| 亚洲理论在线| 亚洲18私人小影院| 国产精品99精品无码视| 欧美.日韩.国产.一区.二区| 久久精品国产91精品亚洲| 手机看片福利视频| 欧美日韩黑人| 在线视频精品一| 日韩精品久久久久| 国产又猛又黄的视频| 欧美成人黑人| 91久久免费观看| 无码内射中文字幕岛国片| 东京一区二区| 日本道在线观看一区二区| 欧美成人免费高清视频| 欧美成人免费电影| 精品视频在线免费| 999这里有精品| 视频精品国内| 亚洲精品国产精品乱码不99按摩 | 中文在线一区| 日本精品va在线观看| 天堂网视频在线| 日韩国产欧美视频| 国产一区二区色| 不卡视频在线播放| 99久久精品国产麻豆演员表| 久久久久久欧美精品色一二三四| 美州a亚洲一视本频v色道| 久久精品亚洲精品国产欧美 | 欧美不卡高清| 性色av一区二区咪爱| 午夜精品久久久久久久蜜桃| 蜜臀av性久久久久蜜臀av麻豆| 91久久精品国产91久久性色| xxxwww在线观看| 久久综合九色综合欧美就去吻| 日韩在线导航| 亚洲色图美国十次| 欧美特级www| 中文字幕久久av| 国产精品极品国产中出| 蜜桃视频免费观看一区| 一区二区在线视频| 欧美色图亚洲视频| 亚洲欧美成人综合| 91久久在线播放| 日本亚洲欧美| 亚洲欧美色图小说| 黄色片久久久久| 欧美二区观看| 亚洲精品视频在线播放| 911国产在线| 一区二区激情| 91久久中文字幕| 视频二区在线| 一区二区三区四区亚洲| 手机看片福利日韩| 欧美成人午夜77777| 少妇激情综合网| 99久在线精品99re8热| 精品一区二区免费视频| 久久久综合亚洲91久久98| 午夜在线小视频| 精品日韩中文字幕| 成人啪啪18免费游戏链接| 日本成人小视频| 992tv成人免费影院| 国产在成人精品线拍偷自揄拍| 99久久综合精品| 久久久天堂国产精品| 日本成人福利| 日韩av在线看| 久草视频免费在线播放| 美女国产一区二区三区| 欧美人与物videos另类| av在线视屏| 日韩一区二区电影在线| 影音先锋男人资源在线观看| 丝袜亚洲另类欧美| 免费在线成人av电影| 欧美一卡二卡| 91精品国产一区二区三区香蕉| 国产精品久久久久久久av| 亚洲一区欧美二区| 狠狠色狠狠色综合人人| 欧美色图天堂| 欧美一二三四区在线| 欧美自拍偷拍网| 天天操天天舔天天干| 99在线精品观看| 分分操这里只有精品| 欧州一区二区三区| 欧美成人午夜免费视在线看片| 亚洲无码久久久久| 国产精品麻豆一区二区| 男女男精品视频站| 精品香蕉视频| 国产精品美乳在线观看| 成人午夜在线观看视频| 欧美影院一区二区三区| 在线观看日本中文字幕| 日韩一区精品视频| 性刺激综合网| 日韩福利影视| 免费99精品国产自在在线| 国产免费的av| 亚洲一区二区在线免费观看视频| 免费不卡av网站| 午夜久久福利| 国产精品v欧美精品v日韩| 欧美另类tv| 亚洲国产精品久久久久秋霞不卡| 久久激情免费视频| 成人免费精品视频| 日韩av黄色网址| 国内精品久久久久久久久电影网 | 99精品热视频| 无码人妻丰满熟妇区毛片| 欧美影院三区| 91麻豆国产精品| 国产深夜视频在线观看| 亚洲成人av资源网| 中文字幕手机在线视频| 国产精品久久久久久久久快鸭| 亚洲天堂av一区二区| 欧美精品国产一区二区| 国产伦精品一区二区三区视频黑人 | 69av成年福利视频| 国产小视频在线播放| 欧美日韩国产精品自在自线| 日韩女优一区二区| av影院午夜一区| 欧美日韩美女视频| 亚洲视频 中文字幕| 国产一区二区三区的电影| 日韩欧美亚洲v片| 国产日韩欧美中文在线| 亚洲91av视频| 99视频在线观看地址| 日韩片之四级片| 东京热一区二区三区四区| 中文字幕国产精品一区二区| 原创真实夫妻啪啪av| 午夜一区二区三区不卡视频| 亚洲精品国产系列| 国产日韩在线观看视频| 欧美一级bbbbb性bbbb喷潮片| 97在线观看免费观看高清 | 88国产精品视频一区二区三区| 韩国成人一区| 不卡一区视频| 国产精品av在线播放| 神马午夜伦理不卡| 在线观看精品国产视频| 人妻va精品va欧美va| 欧美日韩一级大片网址| 日韩免费一级片| 亚洲欧美日韩在线播放| 国产真实乱人偷精品人妻| 精品一区二区三区视频| av免费网站观看| 在线观看的日韩av| 麻豆md0077饥渴少妇| 妖精视频一区二区三区免费观看| 亚洲a中文字幕| 岛国精品在线| 日韩av第一页| 乡村艳史在线观看| 国内精品久久久久影院优| 麻豆视频免费在线观看| 亚洲视频精品在线| 四虎永久在线观看| 日韩欧美高清一区| 国产精品九九九九| 欧美日韩视频第一区| 四虎精品永久在线| 天天影视色香欲综合网老头| 91久久国产综合| 国产精品私人自拍| 久久久久久国产免费a片| 波多野结衣中文字幕一区二区三区 | 日韩久久免费电影| 欧洲精品久久一区二区| 精品欧美一区二区三区精品久久 | 国产一区二区调教| 国产成年人视频网站| 秋霞电影一区二区| 欧美一级黄色片视频| 999亚洲国产精| 欧美成人高潮一二区在线看| 影音先锋日韩在线| 一级全黄肉体裸体全过程| 久久亚洲精品中文字幕蜜潮电影| 日日骚一区二区网站| 国产亚洲欧美日韩在线观看一区二区| 久久国产手机看片| 西野翔中文久久精品国产| 精品国产乱码久久久久久88av| 北条麻妃在线一区二区免费播放 | 国产视频一区欧美| 精品国产一二三四区| 99re国产精品| 青青视频在线播放| 久久久久久网| 中文字幕在线观看第三页| 日本不卡中文字幕| 五月婷婷之婷婷| 成人无码av片在线观看| 成人久久综合| 色一情一乱一伦一区二区三欧美| 国产精品一区高清| 亚洲777理论| 欧美日韩免费一区二区| 亚洲美女屁股眼交| 精国产品一区二区三区a片| 亚洲精品乱码久久久久| 国产性生活网站| 精品久久久久人成| 国产美女www爽爽爽| 欧美日本韩国一区| 国产成人av免费看| 日韩大陆欧美高清视频区| 视频一区二区三区国产| 亚洲偷欧美偷国内偷| 无遮挡动作视频在线观看免费入口| 日韩中文字幕在线播放| 在线heyzo| 不卡的av在线| 999这里有精品| 成人免费va视频| 欧美偷拍一区二区三区| 中文字幕日本不卡| 黄色小视频在线免费看| 色婷婷久久一区二区三区麻豆| 伊人精品在线视频| 欧美精品一区二区久久婷婷| 激情小视频在线观看| 久久国产精品亚洲| 女厕盗摄一区二区三区| 国产剧情久久久久久| 黄色美女久久久| 一区二区三区四区五区精品| 欧美视频一区| 亚洲精品一二三四五区| 成人小视频在线| 在线免费观看视频| 亚洲成人免费在线观看| 中文字幕第99页| 亚洲第一区在线观看| 亚洲精品承认| 欧美亚洲视频一区二区| 秋霞一区二区| 日韩欧美精品久久| 亚洲激情网站| 日韩av片免费观看| 国产亚洲成aⅴ人片在线观看| 免费在线看黄网址| 欧美三级三级三级爽爽爽| 国产综合无码一区二区色蜜蜜| 中文字幕欧美国内| 亚洲黄色免费av| 99re视频在线观看| 成人久久综合| 成年网站在线免费观看| 国产电影精品久久禁18| av网在线播放| 欧美性xxxxxxxxx| www香蕉视频| 久久久www成人免费精品张筱雨| www.com.cn成人| 久久精品日产第一区二区三区乱码| 亚洲va在线| 国产精品自拍视频在线| 久久久一区二区三区| 国产精品99精品无码视| 欧美一区二区三区日韩视频| av每日在线更新| 国产精品久久久久久久久久久不卡 | 一区二区三区.www| jizz国产视频| 另类美女黄大片| 国产精品天堂蜜av在线播放| 农村寡妇一区二区三区| 在线亚洲成人| 国产草草浮力影院| 婷婷丁香激情综合| 亚洲精品第五页| 欧美激情伊人电影 | 国产精品久久久久久久第一福利| 五月天丁香综合久久国产| 欧美成人日韩| 69久久精品无码一区二区| 成人欧美一区二区三区| 中文字幕男人天堂| 这里只有精品视频| 91天天综合| 亚洲一区二区三区加勒比| 秋霞影院一区二区| 国产亚洲精品久久久久久豆腐| 欧美日韩精品一区二区三区 | 亚洲一区成人在线| 亚洲乱码在线观看| 欧美激情在线狂野欧美精品| 一区视频网站| 国产精品国产亚洲精品看不卡| 成人免费高清在线| 五月婷婷视频在线| 国产一区二区三区网站| 成人免费一区| 91社在线播放| 成人亚洲精品久久久久软件| 久草精品视频在线观看| 国产视频丨精品|在线观看| 欧美精品日日操| 在线国产99| 国产精品一二三区| 偷偷操不一样的久久| 亚洲欧美激情精品一区二区| 日本一区二区三区视频在线| 亚洲国产午夜伦理片大全在线观看网站 | 91在线免费看网站| 欧美日韩亚洲一区二区三区在线| 欧美肉大捧一进一出免费视频| 日韩欧美黄色动漫| 在线播放毛片| 成人午夜影院在线观看| 国产精品亚洲欧美| 三级黄色片在线观看| 精品国产三级电影在线观看| 亚洲精品中文字幕| 在线国产精品网| 91在线视频官网| 中文字幕av影视| 国模私拍一区二区三区| 成人中文在线| 国产人妖在线观看| 日本久久电影网| 手机在线免费观看av| 日本精品一区二区| 国产河南妇女毛片精品久久久| 久久久国产精品成人免费| 色系列之999| 任你躁在线精品免费| 97超碰成人在线| 亚洲高清视频的网址| jizz视频在线观看| 国产精品一级久久久| 麻豆免费精品视频| 天堂中文字幕在线观看| 欧美成人在线网站| 神马久久久久久久久久| 亚洲国产精品久久久久| 日韩毛片免费看| 亚洲爆乳无码专区| 亚洲第一搞黄网站| h片在线免费|