mysql 5.7 flashback_Flashback for MySQL 5.7
實現(xiàn)原理
flashback的概念最早出現(xiàn)于Oracle數(shù)據(jù)庫,用于快速恢復(fù)用戶的誤操作。
flashback for MySQL用于恢復(fù)由DML語句引起的誤操作,目前不支持DDL語句。例如下面的語句:
DELETE FROM XXX;
UPDATE XXX SET YYY=ZZZ;
若沒有flashback功能,那么當(dāng)發(fā)生誤操作時,用戶只能通過全備+二進制日志前滾的方式進行恢復(fù)。通常來說,這樣所需的恢復(fù)時間會非常長。為了縮短誤操作恢復(fù)的時間,通常可以在slave上搭建LVM,通過定期快照的方式來縮短誤操作的恢復(fù)時間。但是LVM快照的缺點是會對slave的性能產(chǎn)生一定的影響。
官方mysqlbinlog命令為解析MySQL的二進制日志。當(dāng)二進制日志的格式為ROW格式時,可以輸出每個操作的每條記錄的前項與后項。那么通過逆操作即可進行回滾操作,例如:
原始操作:INSERT INTO ...
flashback操作:DELETE ...
原始操作:DELETE FROM ...
flashback操作:INSERT INTO ...
原始操作:UPDATE XXX SET OLD_VALUES ...
flashback操作:UPDATE XXX SET NEW_VALUES ...
目前flashback功能集成于官方mysqlbinlog命令,通過參數(shù)的方式進行flashback功能的開啟。
相關(guān)參數(shù)
-B --flashback
flashback核心參數(shù),回滾二進制日志
root@test-1:~# ./mysqlbinlog -B --base64-output=decode-rows ?-vv /mdata/mysql_data_old/bin.000008
......
-A --skip_database
解析BinLog時過濾掉該數(shù)據(jù)庫。
-a --skip_table
解析BinLog時過濾掉該表,一般與skip_datebase配套使用。
-O --split-size-interval
將BinLog文件按照指定的大小拆分為多個段,解析結(jié)果為打印每個段的起始o(jì)ffset位置。
注意,當(dāng)進行flashback時,flashback的內(nèi)容先保存在內(nèi)存中。若你的binlog大小為10G,那么需要額外的10G內(nèi)存先暫時保存這部分信息。在某些情況下,如云環(huán)境、或服務(wù)器內(nèi)存較小,會導(dǎo)致無法輸出flashback的日志。這時可以通過此參數(shù)來設(shè)置內(nèi)存保存文件的大小,例如將此值設(shè)置為100M,那么每100M就會刷新到一個文件。
-D --datetime_to_pos
基于輸入的時間信息,解析出該時間對應(yīng)的第一個BinLog event偏移位置,格式參照start-datetime,
flashback時要先找到起始的偏移量,DBA可以先通過此參數(shù)定位到具體位置,然后再進行flashback操作。
-T --table
僅解析該表,一般與database配套使用。
-E --fb_event
僅解析該類型的Log event,一般與database、table選項配套使用??蛇x的值有:
DELETE
INSERT
UPDATE
關(guān)于DDL的flashback功能
flashback功能僅支持DML語句的快速恢復(fù),但是如果誤操作為DDL的話,那么就無能為力了,比如:
TRUNCATE TABLE ?xxx;
DROP TABLE xxxx;
DROP DATABASE xxx;
若要支持上述的快速flashback功能,需要修改MySQL源代碼,將刪除的庫或者表保存到一個垃圾回收的庫中,例如$RECYCLE庫。想要支持這個功能,可以考慮使用InnoSQL商業(yè)版本。
視頻
視頻是最好的文檔
下載地址
下載地址?如需技術(shù)支持,可微信聯(lián)系:82946772。
原文:http://www.cnblogs.com/276815076/p/6102641.html
總結(jié)
以上是生活随笔為你收集整理的mysql 5.7 flashback_Flashback for MySQL 5.7的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 腾讯移动分析+html5,FAQ · 腾
- 下一篇: python编程求极限_Sympy笔记一