av一区二区在线观看_亚洲男人的天堂网站_日韩亚洲视频_在线成人免费_欧美日韩精品免费观看视频_久草视

您的位置:首頁技術(shù)文章
文章詳情頁

MySQL 撤銷日志與重做日志(Undo Log與Redo Log)相關(guān)總結(jié)

瀏覽:2日期:2023-10-04 15:51:50
Undo Log

數(shù)據(jù)庫事務(wù)開始之前,會將要修改的記錄存放到 Undo 日志里,當事務(wù)回滾時或者數(shù)據(jù)庫崩潰時,可以利用 Undo 日志,撤銷未提交事務(wù)對數(shù)據(jù)庫產(chǎn)生的影響。

Undo Log產(chǎn)生和銷毀

Undo Log在事務(wù)開始前產(chǎn)生;事務(wù)在提交時,并不會立刻刪除undo log,innodb會將該事務(wù)對應(yīng)的undo log放入到刪除列表中,后面會通過后臺線程purge thread進行回收處理。Undo Log屬于邏輯日志,記錄一個變化過程。例如執(zhí)行一個delete,undolog會記錄一個insert;執(zhí)行一個update,undolog會記錄一個相反的update。

Undo Log存儲

Undo log采用段的方式管理和記錄。在innodb數(shù)據(jù)文件中包含一種rollback segment回滾段,內(nèi)部包含1024個undo log segment。可以通過下面一組參數(shù)來控制Undo log存儲。

show variables like ’%innodb_undo%’; Undo Log作用實現(xiàn)事務(wù)的原子性

Undo Log 是為了實現(xiàn)事務(wù)的原子性而出現(xiàn)的產(chǎn)物。事務(wù)處理過程中,如果出現(xiàn)了錯誤或者用戶執(zhí)行了 ROLLBACK 語句,MySQL 可以利用 Undo Log 中的備份將數(shù)據(jù)恢復到事務(wù)開始之前的狀態(tài)。

實現(xiàn)多版本并發(fā)控制(MVCC)

Undo Log 在 MySQL InnoDB 存儲引擎中用來實現(xiàn)多版本并發(fā)控制。事務(wù)未提交之前,Undo Log保存了未提交之前的版本數(shù)據(jù),Undo Log 中的數(shù)據(jù)可作為數(shù)據(jù)舊版本快照供其他并發(fā)事務(wù)進行快照讀。

事務(wù)A手動開啟事務(wù),執(zhí)行更新操作,首先會把更新命中的數(shù)據(jù)備份到 Undo Buffer中。事務(wù)B手動開啟事務(wù),執(zhí)行查詢操作,會讀取 Undo 日志數(shù)據(jù)返回,進行快照讀

Redo Log

指事務(wù)中修改的任何數(shù)據(jù),將最新的數(shù)據(jù)備份存儲的位置(Redo Log),被稱為重做日志。

Redo Log 的生成和釋放

隨著事務(wù)操作的執(zhí)行,就會生成Redo Log,在事務(wù)提交時會將產(chǎn)生Redo Log寫入Log Buffer,并不是隨著事務(wù)的提交就立刻寫入磁盤文件。等事務(wù)操作的臟頁寫入到磁盤之后,Redo Log 的使命也就完成了,Redo Log占用的空間就可以重用(被覆蓋寫入)。

Redo Log 工作原理

Redo Log 是為了實現(xiàn)事務(wù)的持久性而出現(xiàn)的產(chǎn)物。防止在發(fā)生故障的時間點,尚有臟頁未寫入表的 ibd 文件中,在重啟 MySQL 服務(wù)的時候,根據(jù) Redo Log 進行重做,從而達到事務(wù)的未入磁盤數(shù)據(jù)進行持久化這一特性。

Redo Log 寫入機制

Redo Log 文件內(nèi)容是以順序循環(huán)的方式寫入文件,寫滿時則回溯到第一個文件,進行覆蓋寫

MySQL 撤銷日志與重做日志(Undo Log與Redo Log)相關(guān)總結(jié)

write pos 是當前記錄的位置,一邊寫一邊后移,寫到最后一個文件末尾后就回到 0 號文件開頭;checkpoint 是當前要擦除的位置,也是往后推移并且循環(huán)的,擦除記錄前要把記錄更新到數(shù)據(jù)文件;write pos 和 checkpoint 之間還空著的部分,可以用來記錄新的操作。如果 write pos 追上checkpoint,表示寫滿,這時候不能再執(zhí)行新的更新,得停下來先擦掉一些記錄,把checkpoint 推進一下。

Redo Log相關(guān)配置參數(shù)

每個InnoDB存儲引擎至少有1個重做日志文件組(group),每個文件組至少有2個重做日志文件,默認為ib_logfile0和ib_logfile1。可以通過下面一組參數(shù)控制Redo Log存儲

show variables like ’%innodb_log%’;

Redo Buffer 持久化到 Redo Log 的策略,可通過 Innodb_flush_log_at_trx_commit 設(shè)置

0:每秒提交 Redo buffer ->OS cache -> flush cache to disk,可能丟失一秒內(nèi)的事務(wù)數(shù)據(jù)。由后臺Master線程每隔 1秒執(zhí)行一次操作。1(默認值):每次事務(wù)提交執(zhí)行 Redo Buffer -> OS cache -> flush cache to disk,最安全,性能最差的方式。2:每次事務(wù)提交執(zhí)行 Redo Buffer -> OS cache,然后由后臺Master線程再每隔1秒執(zhí)行OS cache -> flush cache to disk 的操作。

一般建議選擇取值2,因為 MySQL 掛了數(shù)據(jù)沒有損失,整個服務(wù)器掛了才會損失1秒的事務(wù)提交數(shù)據(jù)。

MySQL 撤銷日志與重做日志(Undo Log與Redo Log)相關(guān)總結(jié)

以上就是MySQL 撤銷日志與重做日志(Undo Log與Redo Log)相關(guān)總結(jié)的詳細內(nèi)容,更多關(guān)于MySQL 撤銷日志與重做日志(Undo Log與Redo Log)的資料請關(guān)注好吧啦網(wǎng)其它相關(guān)文章!

相關(guān)文章:
主站蜘蛛池模板: 免费高潮视频95在线观看网站 | 国产成人99久久亚洲综合精品 | www国产成人免费观看视频,深夜成人网 | 亚洲高清在线 | 国产成人网 | 日韩欧美中文字幕在线观看 | 成人精品一区二区三区 | 欧美一区二区视频 | 性欧美xxxx| 亚洲嫩草| 91极品尤物在线播放国产 | 欧美日韩成人影院 | 欧美精品在线看 | 亚洲一区二区三区观看 | 日韩在线观看视频一区 | 精品国产欧美 | 日本在线视频中文字幕 | 91资源在线 | 亚洲不卡在线观看 | 欧美黄在线观看 | 羞羞视频一区二区 | 午夜精品久久久久久久久久久久久 | 成人在线视频免费看 | avmans最新导航地址 | 亚洲精品久久久久国产 | 日韩欧美精品一区 | 日本精品久久久久 | 成人黄色在线 | 日韩中出| 亚洲男女视频在线观看 | 亚洲国产高清高潮精品美女 | 精品综合 | 夜夜骑天天干 | 九九99九九精彩46 | 成人av一区二区三区 | 欧美片网站免费 | 欧美黄视频 | 日韩精品一区二区三区视频播放 | 亚洲在线免费观看 | 国产一区91精品张津瑜 | 天天草夜夜骑 |