日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

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

詳解MySQL中事務(wù)的持久性實(shí)現(xiàn)原理

瀏覽:121日期:2023-10-06 12:20:02
前言

說到數(shù)據(jù)庫事務(wù),大家腦子里一定很容易蹦出一堆事務(wù)的相關(guān)知識,如事務(wù)的ACID特性,隔離級別,解決的問題(臟讀,不可重復(fù)讀,幻讀)等等,但是可能很少有人真正的清楚事務(wù)的這些特性又是怎么實(shí)現(xiàn)的,為什么要有四個(gè)隔離級別。

在之前的文章我們已經(jīng)了解了MySQL中事務(wù)的隔離性的實(shí)現(xiàn)原理,今天就繼續(xù)來聊一聊MySQL持久性的實(shí)現(xiàn)原理。

當(dāng)然MySQL博大精深,文章疏漏之處在所難免,歡迎批評指正。

說明

MySQL的事務(wù)實(shí)現(xiàn)邏輯是位于引擎層的,并且不是所有的引擎都支持事務(wù)的,下面的說明都是以InnoDB引擎為基準(zhǔn)。

InnoDB讀寫數(shù)據(jù)原理

在往下學(xué)習(xí)之前,我們需要先來了解下InnoDB是怎么來讀寫數(shù)據(jù)的。我們知道數(shù)據(jù)庫的數(shù)據(jù)都是存放在磁盤中的,然后我們也知道磁盤I/O的成本是很大的,如果每次讀寫數(shù)據(jù)都要訪問磁盤,數(shù)據(jù)庫的效率就會非常低。為了解決這個(gè)問題,InnoDB提供了 Buffer Pool 作為訪問數(shù)據(jù)庫數(shù)據(jù)的緩沖。

Buffer Pool 是位于內(nèi)存的,包含了磁盤中部分?jǐn)?shù)據(jù)頁的映射。當(dāng)需要讀取數(shù)據(jù)時(shí),InnoDB會首先嘗試從Buffer Pool中讀取,讀取不到的話就會從磁盤讀取后放入Buffer Pool;當(dāng)寫入數(shù)據(jù)時(shí),會先寫入Buffer Pool的頁面,并把這樣的頁面標(biāo)記為dirty,并放到專門的flush list上,這些修改的數(shù)據(jù)頁會在后續(xù)某個(gè)時(shí)刻被刷新到磁盤中(這一過程稱為刷臟,由其他后臺線程負(fù)責(zé)) 。如下圖所示:

詳解MySQL中事務(wù)的持久性實(shí)現(xiàn)原理

這樣設(shè)計(jì)的好處是可以把大量的磁盤I/O轉(zhuǎn)成內(nèi)存讀寫,并且把對一個(gè)頁面的多次修改merge成一次I/O操作(刷臟一次刷入整個(gè)頁面),避免每次讀寫操作都訪問磁盤,從而大大提升了數(shù)據(jù)庫的性能。

持久性定義

持久性是指事務(wù)一旦提交,它對數(shù)據(jù)庫的改變就應(yīng)該是永久性的,接下來的其他操作或故障不應(yīng)該對本次事務(wù)的修改有任何影響。

通過前面的介紹,我們知道InnoDB使用 Buffer Pool 來提高讀寫的性能。但是 Buffer Pool 是在內(nèi)存的,是易失性的,如果一個(gè)事務(wù)提交了事務(wù)后,MySQL突然宕機(jī),且此時(shí)Buffer Pool中修改的數(shù)據(jù)還沒有刷新到磁盤中的話,就會導(dǎo)致數(shù)據(jù)的丟失,事務(wù)的持久性就無法保證。

為了解決這個(gè)問題,InnoDB引入了 redo log來實(shí)現(xiàn)數(shù)據(jù)修改的持久化。當(dāng)數(shù)據(jù)修改時(shí),InnoDB除了修改Buffer Pool中的數(shù)據(jù),還會在redo log 記錄這次操作,并保證redo log早于對應(yīng)的頁面落盤(一般在事務(wù)提交的時(shí)候),也就是常說的WAL。若MySQL突然宕機(jī)了且還沒有把數(shù)據(jù)刷回磁盤,重啟后,MySQL會通過已經(jīng)寫入磁盤的redo log來恢復(fù)沒有被刷新到磁盤的數(shù)據(jù)頁。

實(shí)現(xiàn)原理:redo log

為了提高性能,和數(shù)據(jù)頁類似,redo log 也包括兩部分:一是內(nèi)存中的日志緩沖(redo log buffer),該部分日志是易失性的;二是磁盤上的重做日志文件(redo log file),該部分日志是持久的。redo log是物理日志,記錄的是數(shù)據(jù)庫中物理頁的情況 。

當(dāng)數(shù)據(jù)發(fā)生修改時(shí),InnoDB不僅會修改Buffer Pool中的數(shù)據(jù),也會在redo log buffer記錄這次操作;當(dāng)事務(wù)提交時(shí),會對redo log buffer進(jìn)行刷盤,記錄到redo log file中。如果MySQL宕機(jī),重啟時(shí)可以讀取redo log file中的數(shù)據(jù),對數(shù)據(jù)庫進(jìn)行恢復(fù)。這樣就不需要每次提交事務(wù)都實(shí)時(shí)進(jìn)行刷臟了。

寫入過程

注意點(diǎn):

先修改Buffer Pool,后寫 redo log buffer。 redo日志比數(shù)據(jù)頁先寫回磁盤:事務(wù)提交的時(shí)候,會把redo log buffer寫入redo log file,寫入成功才算提交成功(也有其他場景觸發(fā)寫入,這里就不展開了),而Buffer Pool的數(shù)據(jù)由后臺線程在后續(xù)某個(gè)時(shí)刻寫入磁盤。 刷臟的時(shí)候一定會保證對應(yīng)的redo log已經(jīng)落盤了,也即是所謂的WAL(預(yù)寫式日志),否則會有數(shù)據(jù)丟失的可能性。 好處

事務(wù)提交的時(shí)候,寫入redo log 相比于直接刷臟的好處主要有三點(diǎn):

刷臟是隨機(jī)I/O,但寫redo log 是順序I/O,順序I/O可比隨機(jī)I/O快多了,不需要。刷臟是以數(shù)據(jù)頁(Page)為單位的,即使一個(gè)Page只有一點(diǎn)點(diǎn)修改也要整頁寫入;而redo log中只包含真正被修改的部分,數(shù)據(jù)量非常小,無效IO大大減少。刷臟的時(shí)候可能要刷很多頁的數(shù)據(jù),無法保證原子性(例如只寫了一部分?jǐn)?shù)據(jù)就失敗了),而redo log buffer 向 redo log file 寫log block,是按512個(gè)字節(jié),也就是一個(gè)扇區(qū)的大小進(jìn)行寫入,扇區(qū)是寫入的最小單位,因此可以保證寫入是必定成功的。

先寫redo log還是先修改數(shù)據(jù)

一次DML可能涉及到數(shù)據(jù)的修改和redo log的記錄,那它們的執(zhí)行順序是怎么樣的呢?網(wǎng)上的文章有的說先修改數(shù)據(jù),后記錄redo log,有的說先記錄redo log,后改數(shù)據(jù),那真實(shí)的情況是如何呢?

首先通過上面的說明我們知道,redo log buffer在事務(wù)提交的時(shí)候就會寫入redo log file的,而刷臟則是在后續(xù)的某個(gè)時(shí)刻,所以可以確定的是先記錄redo log,后修改data page(WAL當(dāng)然是日志先寫啦)。

那接下來的問題就是先寫redo log buffer還是先修改Buffer Pool了。要了解這個(gè)問題,我們先要了解InnoDB中,一次DML的執(zhí)行過程是怎么樣的。一次DML的執(zhí)行過程涉及了數(shù)據(jù)的修改,加鎖,解鎖,redo log的記錄和undo log的記錄等,也是需要保證原子性的,而InnoDB通過MTR(Mini-transactions)來保證一次DML操作的原子性。

首先來看MTR的定義:

An internal phase of InnoDB processing, when making changes at the physical level to internal data structures during DML operations. A Mini-transactions (mtr) has no notion of rollback; multiple Mini-transactionss can occur within a single transaction. Mini-transactionss write information to the redo log that is used during crash recovery. A Mini-transactions can also happen outside the context of a regular transaction, for example during purge processing by background threads. 見 https://dev.mysql.com/doc/refman/8.0/en/glossary.html

MTR 是一個(gè)短原子操作,不能回滾,因?yàn)樗旧砭褪窃拥摹?shù)據(jù)頁的變更必須通過MTR,MTR 會把DML操作對數(shù)據(jù)頁的修改記錄到 redo log里。

下面來簡單看下MTR的過程:

MTR初始化的時(shí)候會初始化一份 mtr_buf 當(dāng)修改數(shù)據(jù)時(shí),在對內(nèi)存Buffer Pool中的頁面進(jìn)行修改的同時(shí),還會生成redo log record,保存在mtr_buf中。 在執(zhí)行mtr_commit函數(shù)提交本MTR的時(shí)候,會將mtr_buf中的redo log record更新到redo log buffer中,同時(shí)將臟頁添加到flush list,供后續(xù)刷臟使用。在log buffer中,每接收到496字節(jié)的log record,就將這組log record包裝一個(gè)12字節(jié)的block header和一個(gè)4字節(jié)的block tailer,成為一個(gè)512字節(jié)的log block,方便刷盤的時(shí)候?qū)R512字節(jié)刷盤。

由此可見,InnoDB是先修改Buffer Pool,后寫redo log buffer的。

恢復(fù)數(shù)據(jù)的過程

在任何情況下,InnoDB啟動時(shí)都會嘗試執(zhí)行recovery操作。在恢復(fù)過程中,需要redo log參與,而如果還開啟了binlog,那就還需要binlog、undo log的參與。因?yàn)橛锌赡軘?shù)據(jù)已經(jīng)寫入binlog了,但是redo log還沒有刷盤的時(shí)候數(shù)據(jù)庫就奔潰了(事務(wù)是InnoDB引擎的特性,修改了數(shù)據(jù)不一定提交了,而binlog是MySQL服務(wù)層的特性,修改數(shù)據(jù)就會記錄了),這時(shí)候就需要redo log,binlog和undo log三者的參與來判斷是否有還沒提交的事務(wù),未提交的事務(wù)進(jìn)行回滾或者提交操作。

下面來簡單說下僅利用redo log恢復(fù)數(shù)據(jù)的過程:

啟動InnoDB時(shí),找到最近一次Checkpoint的位置,利用Checkpoint LSN去找大于該LSN的redo log進(jìn)行日志恢復(fù)。 如果中間恢復(fù)失敗了也沒影響,再次恢復(fù)的時(shí)候還是從上次保存成功的Checkpoint的位置繼續(xù)恢復(fù)。

Recover過程:故障恢復(fù)包含三個(gè)階段:Analysis,Redo和Undo。Analysis階段的任務(wù)主要是利用Checkpoint及Log中的信息確認(rèn)后續(xù)Redo和Undo階段的操作范圍,通過Log修正Checkpoint中記錄的Dirty Page集合信息,并用其中涉及最小的LSN位置作為下一步Redo的開始位置RedoLSN。同時(shí)修正Checkpoint中記錄的活躍事務(wù)集合(未提交事務(wù)),作為Undo過程的回滾對象;Redo階段從Analysis獲得的RedoLSN出發(fā),重放所有的Log中的Redo內(nèi)容,注意這里也包含了未Commit事務(wù);最后Undo階段對所有未提交事務(wù)利用Undo信息進(jìn)行回滾,通過Log的PrevLSN可以順序找到事務(wù)所有需要回滾的修改。具體見 http://catkang.github.io/2019/01/16/crash-recovery.html

什么是LSN?

LSN也就是log sequence number,也日志的序列號,是一個(gè)單調(diào)遞增的64位無符號整數(shù)。redo log和數(shù)據(jù)頁都保存著LSN,可以用作數(shù)據(jù)恢復(fù)的依據(jù)。LSN更大的表示所引用的日志記錄所描述的變化發(fā)生在更后面。

什么是Checkpoint?

Checkpoint表示一個(gè)保存點(diǎn),在這個(gè)點(diǎn)之前的數(shù)據(jù)頁的修改(log LSN<Checkpoint LSN)都已經(jīng)寫入磁盤文件了。InnoDB每次刷盤之后都會記錄Checkpoint,把最新的redo log LSN 記錄到Checkpoint LSN 里,方便恢復(fù)數(shù)據(jù)的時(shí)候作為起始點(diǎn)的判斷。

以上就是詳解MySQL中事務(wù)的持久性實(shí)現(xiàn)原理的詳細(xì)內(nèi)容,更多關(guān)于MySQL 事務(wù)的持久性的資料請關(guān)注好吧啦網(wǎng)其它相關(guān)文章!

標(biāo)簽: MySQL 數(shù)據(jù)庫
相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
国产精品毛片一区二区在线看| 婷婷成人基地| 黑丝一区二区三区| 国产一区二区久久久久| 国产亚洲一区| 久久不见久久见中文字幕免费| 国产欧美一区二区三区精品观看| 日韩在线观看中文字幕| 日本v片在线高清不卡在线观看| 亚洲三级网址| 日韩欧美激情| 日韩av一区二区三区四区| 亚州欧美在线| 久久国产视频网| 国产精品亚洲综合色区韩国| 日韩美女国产精品| 国产精品亚洲片在线播放| 国产精品大片| 九九九精品视频| 国产精品超碰| 欧美日韩免费观看视频| 久久精品国产亚洲夜色av网站| 亚洲婷婷在线| 喷白浆一区二区| 国产精品一区二区中文字幕| 精品国产一区二| 久久久久久久久久久9不雅视频| 亚洲欧美日韩高清在线| 欧美激情另类| 亚洲精品国产精品粉嫩| 国产精品久久久免费| 久久久天天操| 亚洲91网站| 国产九一精品| 99精品视频在线| 亚洲aⅴ网站| 久久精品国产亚洲aⅴ| 国产91久久精品一区二区| 亚洲精品乱码日韩| 精品国产99| 午夜在线播放视频欧美| 国产精品久久久久久久久久齐齐 | 激情六月综合| 亚洲一区av| 精品精品国产三级a∨在线| 在线一区免费| 国产精品久久久久久久久久白浆| 久久久成人网| 欧美日韩一区二区国产| 四虎影视精品| 国产视频一区二| 激情偷拍久久| 麻豆精品蜜桃视频网站| 亚洲黄色影院| 精品视频在线观看网站| 综合激情在线| 成人三级高清视频在线看| 免费精品视频最新在线| 91亚洲国产成人久久精品| 蜜臀精品一区二区三区在线观看| 精品无人区麻豆乱码久久久| 亚洲有吗中文字幕| av亚洲在线观看| 久久字幕精品一区| 亚洲精品护士| 制服诱惑一区二区| 亚洲综合电影| 欧美韩一区二区| 日韩一区精品字幕| 亚洲天堂1区| 老司机精品视频在线播放| 在线精品小视频| 国产精品99在线观看| 亚洲人成精品久久久| 日韩精品欧美| 国产一区国产二区国产三区| 91精品福利观看| 日韩在线播放一区二区| 亚洲大全视频| 久久久久久黄| 日韩久久精品| 免费一级欧美在线观看视频| 亚洲2区在线| 亚洲天堂日韩在线| 国产视频一区在线观看一区免费| 成人在线免费观看网站| 日韩高清一区| 爽爽淫人综合网网站| 极品日韩av| 久久天堂精品| www.com.cn成人| 精品精品久久| 免费观看亚洲天堂| 国产精品亚洲综合色区韩国| 日韩国产精品久久久| 亚洲综合婷婷| 只有精品亚洲| 亚洲日本免费电影| 亚洲三级在线| 日韩精品免费一区二区夜夜嗨| 免费在线观看成人| 中文字幕亚洲精品乱码| 一区福利视频| 欧美va亚洲va日韩∨a综合色| 日韩在线不卡| 婷婷激情一区| 91精品精品| 不卡av一区二区| 激情久久婷婷| 国产精品日本| 免费观看在线综合色| 日韩影院精彩在线| 亚洲精品一二三**| 欧美久久一区二区三区| 国产精品v日韩精品v欧美精品网站| 国产精品videossex久久发布 | 免费一级欧美在线观看视频 | 欧美片网站免费| 国产精品日韩精品在线播放| 亚洲欧美日韩国产综合精品二区| 99国产精品久久久久久久成人热| 99re国产精品| 亚洲精品美女91| 国产亚洲欧美日韩精品一区二区三区 | 日韩一区二区三免费高清在线观看 | 国产劲爆久久| 精品视频亚洲| 99精品综合| 欧美日韩视频免费观看| 亚洲一区区二区| 国际精品欧美精品| 亚洲三级视频| 亚洲视频二区| 超碰成人av| 国产精品色在线网站| 美女久久网站| 一二三区精品| 国产欧美日韩一级| 国产免费播放一区二区| 在线一区视频| 视频一区二区不卡| 日韩中文字幕| 日韩国产欧美在线播放| 国产亚洲电影| 国产婷婷精品| a国产在线视频| 国产精品视频一区二区三区综合| 福利一区和二区| 日本欧美韩国一区三区| 色天使综合视频| 亚洲欧洲一区二区天堂久久| 欧美日韩一区二区三区在线电影| 国产欧美69| 九一精品国产| 欧美激情三区| 制服诱惑一区二区| 成人免费一区| 亚洲综合日本| 欧美一区精品| 日本不卡视频一二三区| 丝袜a∨在线一区二区三区不卡| 国产在线观看www| 视频精品一区| 一区二区自拍| 中文字幕高清在线播放| 日本少妇精品亚洲第一区| 亚洲国产一区二区三区在线播放| 美女精品在线观看| 欧美日韩国产亚洲一区| 国产精品一页| 麻豆精品99| 国产欧洲在线| av一区在线| 国产剧情在线观看一区| 久久中文字幕导航| 亚洲夜间福利| 久久亚洲精品中文字幕| 精品1区2区3区4区| 国产精品福利在线观看播放| 男女男精品网站| 在线日韩中文| 麻豆mv在线观看| 日韩av不卡在线观看| 亚洲播播91| 美女视频黄久久| 卡一卡二国产精品| 国产精品最新自拍| 天堂资源在线亚洲| 亚洲欧美日韩视频二区| 日韩精品一二三四| 91精品国产乱码久久久久久久| 国产精品三级| 国产精品a级| 欧美成a人国产精品高清乱码在线观看片在线观看久 | 免费在线观看日韩欧美| 粉嫩av一区二区三区四区五区 | 日韩欧美激情电影| 国产精品普通话对白| 一区二区三区四区在线观看国产日韩| 蜜桃精品视频|