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

一文搞懂Undo Log版本鏈與ReadView機制如何讓事務讀取到該讀的數據

運維 數據庫運維
在 MySQL 的數據表中,存儲著一行行的數據記錄,對每行數據而言,不僅僅記錄著我們定義的字段值,還會隱藏兩個字段:row_trx_id 和 roll_pointer,前者表示更新本行數據的事務 id,后者表示的是回滾指針,它指向的是該行數據上一個版本的 undo log(如果不明白這是什么,可以先繼續往后看)。

[[376055]]

本文轉載自微信公眾號「菜鳥飛呀飛」,作者劉進坤。轉載本文請聯系菜鳥飛呀飛公眾號。   

 undo log 版本鏈

在 MySQL 的數據表中,存儲著一行行的數據記錄,對每行數據而言,不僅僅記錄著我們定義的字段值,還會隱藏兩個字段:row_trx_id 和 roll_pointer,前者表示更新本行數據的事務 id,后者表示的是回滾指針,它指向的是該行數據上一個版本的 undo log(如果不明白這是什么,可以先繼續往后看)。

對于每行有兩個隱藏的字段,在《高性能 MySQL》第三版的第 13 頁中把它們叫做數據的更新時間和過期時間,這兩個字段存儲的不是真實的時間,而是事務的版本號。

這與本文 row_trx_id 和 roll_pointer 的叫法差異很大,實際上,不用在意這兩個字段具體叫什么,反正它們都是為了實現 MVCC 機制而設計的。

我個人覺得把它們分別叫做 row_trx_id 和 roll_pointer,會更容易理解一點。

我們知道,當我們進行數據的新增、刪除、修改操作時,會寫 redo log(解決數據庫宕機重啟丟失數據的問題)和 binlog(主要用來做復制、數據備份等操作),另外還會寫 undo log,它是為了實現事務的回滾操作。

每一條 undo log 的具體內容本文今天先不解釋,有興趣的同學可以自行網上查閱。我們只需要知道每行 undo log 日志會記錄對應的事務 id,還會記錄當前事務將數據修改后的最新值,以及指向當前行數據上一個版本的 undo log 的指針,也就是 roll_pointer。

為了方便理解,每一行 undo log 可以簡化為下圖所示的結構:

圖1

 

舉個例子,現在有一個事務 A,它的事務 id 為 10,向表中新插入了一條數據,數據記為 data_A,那么此時對應的 undo log 應該如下圖所示:

圖2

 

由于是新插入的一條數據,所以這行數據是第一個版本,也就是它沒有上一個數據版本,因此它的 roll_pointer 為 null。

接著事務 B(trx_id=20),將這行數據的值修改為 data_B,同樣也會記錄一條 undo log,如下圖所示,這條 undo log 的 roll_pointer 指針會指向上一個數據版本的 undo log,也就是指向事務 A 寫入的那一行 undo log。

圖3

 

再接著,事務 C(trx_id=30),將這行數據的值修改為 data_C,對應的示意圖如下。

圖4

 

只要有事務修改了這一行的數據,那么就會記錄一條對應的 undo log,一條 undo log 對應這行數據的一個版本,當這行數據有多個版本時,就會有多條 undo log 日志,undo log 之間通過 roll_pointer 指針連接,這樣就形成了一個 undo log 版本鏈

ReadView 機制

當事務在開始執行的時候,會給每個事務生成一個 ReadView。這個 ReadView 會記錄 4 個非常重要的屬性:

  1. creator_trx_id: 當前事務的 id;
  2. m_ids: 當前系統中所有的活躍事務的 id,活躍事務指的是當前系統中開啟了事務,但是還沒有提交的事務;
  3. min_trx_id: 當前系統中,所有活躍事務中事務 id 最小的那個事務,也就是 m_id 數組中最小的事務 id;
  4. max_trx_id: 當前系統中事務的 id 值最大的那個事務 id 值再加 1,也就是系統中下一個要生成的事務 id。

ReadView 會根據這 4 個屬性,再結合 undo log 版本鏈,來實現 MVCC 機制,決定讓一個事務能讀取到哪些數據,不能讀取到哪些數據。

那么到底是如何來實現的呢?

如果用一個坐標軸來表示的話,min_trx_id 和 max_trx_id 會將這個坐標軸分成 3 個部分:

圖5

 

當一個事務讀取某條數據時,就會按照如下規則來決定當前事務能讀取到什么數據:

  1. 如果當前數據的 row_trx_id 小于 min_trx_id,那么表示這條數據是在當前事務開啟之前,其他的事務就已經將該條數據修改了并提交了事務(事務的 id 值是遞增的),所以當前事務能讀取到。
  2. 如果當前數據的 row_trx_id 大于等于 max_trx_id,那么表示在當前事務開啟以后,過了一段時間,系統中有新的事務開啟了,并且新的事務修改了這行數據的值并提交了事務,所以當前事務肯定是不能讀取到的,因此這是后面的事務修改提交的數據。
  3. 如果當前數據的 row_trx_id 處于 min_trx_id 和 max_trx_id 的范圍之間,又需要分兩種情況:

(a)row_trx_id 在 m_ids 數組中,那么當前事務不能讀取到。為什么呢?row_trx_id 在 m_ids 數組中表示的是和當前事務在同一時刻開啟的事務,修改了數據的值,并提交了事務,所以不能讓當前事務讀取到;

(b) row_trx_id 不在 m_ids 數組中,那么當前事務能讀取到。row_trx_id 不在 m_ids 數組中表示的是在當前事務開啟之前,其他事務將數據修改后就已經提交了事務,所以當前事務能讀取到。

注意:如果 row_trx_id 等于當前事務的 id,那表示這條數據就是當前事務修改的,那當前事務肯定能讀取到啊。

這里可能有人會有一個疑惑,事務的 id 值是遞增的,那么在什么場景下,row_trx_id 處于 min_trx_id 和 max_trx_id 之間,但是卻又不再 m_id 數組內呢?

這個問題也是困擾了我很長一段時間,最近終于想通了,答案就是在讀提交的事務隔離級別下,會出現這種現象。

至于為什么,需要看完這一篇文章以及下下一篇文章《在讀提交的事務隔離級別下,MVCC 機制是如何工作的?》,才能明白為什么。

下面舉幾個例子,來解釋一下 ReadView 機制下,數據的讀取規則。先假設表中有一條數據,它的 row_trx_id=10,roll_pointer 為 null,那么此時 undo log 版本鏈就是下圖這樣:

圖6

 

假設現在有事務 A 和事務 B 并發執行,事務 A 的事務 id 為 20,事務 B 的事務 id 為 30。

那么此時對于事務 A 而言,它的 ReadView 中,m_ids=[20,30],min_trx_id=20,max_trx_id=31,creator_trx_id=20。

對于事務 B 而言,它的 ReadView 中,m_ids=[20,30],min_trx_id=20,max_trx_id=31,creator_trx_id=30。

如果此時事務 A(trx_id=20)去讀取數據,那么在 undo log 版本鏈中,數據最新版本的事務 id 為 10,這個值小于事務 A 的 ReadView 里 min_trx_id 的值,這表示這個數據的版本是事務 A 開啟之前,其他事務提交的,因此事務 A 可以讀取到,所以讀取到的值是 data0。

圖7

 

接著事務 B(trx_id=30)去修改數據,將數據修改為 data_B,先不提交事務。雖然不提交事務,但是仍然會記錄一條 undo log,因此這條數據的 undo log 的版本鏈就有兩條記錄了,新的這條 undo log 的 roll_pointer 指針會指向前一條 undo log,示意圖如下。

圖8

 

接著事務 A(trx_id=20)去讀取數據,那么在 undo log 版本鏈中,數據最新版本的事務 id 為 30,這個值處于事務 A 的 ReadView 里 min_trx_id 和 max_trx_id 之間,因此還需要判斷這個數據版本的值是否在 m_ids 數組中,結果發現,30 確實在 m_ids 數組中,這表示這個版本的數據是和自己同一時刻啟動的事務修改的,因此這個版本的數據,數據 A 讀取不到。所以需要沿著 undo log 的版本鏈向前找,接著會找到該行數據的上一個版本,也就是 trx_id=10 的版本,由于這個版本的數據的 trx_id=10,小于 min_trx_id 的值,因此事務 A 能讀取到該版本的值,即事務 A 讀取到的值是 data0。

圖9

 

緊接著事務 B 提交事務,那么此時系統中活躍的事務就只有 id 為 20 的事務了,也就是事務 A。那么此時事務 A 再去讀取數據,它能讀取到什么值呢?還是 data0。為什么呢?

雖然系統中當前只剩下 id 為 20 的活躍事務了,但是事務 A 開啟的瞬間,它已經生成了 ReadView ,后面即使有其他事務提交了,但是事務 A 的 ReadView 不會修改,也就是 m_ids 不會變,還是 m_ids=[20,30],所以此時事務 A 去根據 undo log 版本鏈去讀取數據時,還是不能讀取最新版本的數據,只能往前找,最終還是只能讀取到 data0。

接著系統中,新開了一個事務 C,事務 id 為 40,它的 ReadView 中,m_ids=[20,40],min_trx_id=20,max_trx_id=41,creator_trx_id=40。

然后事務 C(trx_id=40)將數據修改為 data_C,并提交事務。此時 undo log 版本鏈就變成了如下圖所示。

圖10

 

此時事務 A(trx_id=20)去讀取數據,那么在 undo log 版本鏈中,數據最新版本的事務 id 為 40,由于此時事務 A 的 ReadView 中的 max_trx_id=31,40 大于 31,這表示當前版本的數據時在事務 A 之后提交的,因此對于事務 A 肯定是不能讀取到的。所以此時事務 A 只能根據 roll_pointer 指針,沿著 undo log 版本向前找,結果發現上一個版本的 trx_id=30,自己還是不能讀取到,所以再繼續往前找,最終可以讀取到 trx_id=10 的版本數據,因此最終事務 A 只能讀取到 data0。

 


圖11

 

 

接著事務 A(trx_id=20)去修改數據,將數據修改為 data_A,那么就會記錄一條 undo log,示意圖如下:

 

 


圖12

 

 

然后事務 A(trx_id=20)再去讀取數據,在 undo log 版本鏈中,數據最新版本的事務 id 為 20,事務 A 一對比,發現該版本的事務 id 與自己的事務 id 相等,這表示這個版本的數據就是自己修改的,既然是自己修改的,那就肯定能讀取到了,因此此時讀取到是 data_A。

圖13

 

總結

總結一下,本文主要講解了 undo log 版本鏈是如何形成的,然后講解了 ReadView 的機制是什么,通過幾個例子,配合畫圖,詳細分析了 ReadView 結合 undo log 版本鏈是如何來實現讓當前事務讀取到哪一個版本的數據的,這也就是 MVCC 機制的核心實現原理。

但是到目前為止,只是分析了 ReadView 和 undo log 是如何來實現 MVCC 機制,如何控制事務怎么讀取數據,還沒有結合在具體的事務隔離級別下,MVCC 機制是如何工作的。

責任編輯:武曉燕 來源: 菜鳥飛呀飛
相關推薦

2022-04-26 08:00:58

undo日Atomicity事務

2024-01-30 13:15:00

設計模式責任鏈

2024-09-26 07:27:27

2020-05-15 16:37:13

PowerBI數據分析

2025-06-04 03:21:00

RAGRetrievalGeneratio

2022-03-24 08:51:48

Redis互聯網NoSQL

2022-04-26 13:41:16

區塊鏈比特幣數據庫

2024-04-12 12:19:08

語言模型AI

2023-12-06 08:23:16

MVCCmysql

2021-10-20 08:49:30

Vuexvue.js狀態管理模式

2025-01-15 13:19:09

MySQL日志事務

2019-04-03 09:27:01

MySQLInnoDB務ACID

2025-01-16 10:38:31

2025-01-16 00:20:41

2018-03-17 09:00:21

大數據 區塊鏈

2021-03-22 10:05:59

netstat命令Linux

2023-09-08 08:20:46

ThreadLoca多線程工具

2023-09-15 12:00:01

API應用程序接口

2021-02-22 09:44:03

KubernetesDNSLinux

2021-07-28 10:41:21

python
點贊
收藏

51CTO技術棧公眾號

久久精品人人做人人爽电影| 国产亚洲精品久久久| 一区二区三区av| 国产福利小视频| 一本色道88久久加勒比精品| 亚洲午夜久久久影院| 国产免费中文字幕| 91av久久| 国产精品国产精品国产专区不蜜| 成人综合电影| 无码人妻黑人中文字幕| 欧美黄色大片网站| 国产偷国产偷亚洲清高网站| 国产精品久久久久久9999| av影院在线免费观看| 国产精品欧美一区二区三区| 国产精品视频福利| 亚洲在线精品视频| 在线视频免费在线观看一区二区| 久久精品国产亚洲一区二区| 免费观看一级一片| 在线精品视频一区| 欧美日韩黄色一区二区| 成人在线免费在线观看| 91香蕉在线观看| 国产无遮挡一区二区三区毛片日本| 日韩一区在线视频| 亚洲影影院av| 久久久久亚洲av成人毛片韩| 中文字幕一区二区av| 国产午夜精品全部视频播放| 妖精视频一区二区| 香蕉久久一区| 91福利国产精品| 丰满爆乳一区二区三区| 欧美aaaxxxx做受视频| 国产精品看片你懂得| 欧美第一黄网| 午夜激情小视频| 国产经典欧美精品| 91免费看片在线| 在线观看免费中文字幕| 日韩高清不卡一区二区三区| 欧美在线观看网址综合| xxxxxx国产| 亚洲国产国产亚洲一二三| 美女少妇精品视频| 欧美日韩黄色网| 99精品全国免费观看视频软件| 一本久久综合亚洲鲁鲁| 欧美 日韩 国产 成人 在线观看 | 久久福利影院| 在线视频欧美日韩精品| 丰满的亚洲女人毛茸茸| 欧美日韩在线二区| 在线日韩中文字幕| 91禁男男在线观看| 日韩欧美午夜| 最近2019年日本中文免费字幕 | 天天做天天干天天操| 国产精品99久久久久久董美香| 91久久精品一区二区三| caoporn超碰97| 丁香婷婷久久| 欧美丰满一区二区免费视频| aaaaaaaa毛片| 国内精品国产成人国产三级粉色| 亚洲第一二三四五区| 无码精品一区二区三区在线播放 | 日韩精品免费在线视频| 少妇大叫太粗太大爽一区二区| 亚洲另类av| 色偷偷偷综合中文字幕;dd| 人与动物性xxxx| 欧美精品自拍| 26uuu久久噜噜噜噜| 无码人妻精品一区二区三区不卡| 秋霞影院一区二区| 91中文字幕在线| 国产成人三级在线观看视频| 99re热视频精品| 污视频在线免费观看一区二区三区| 自拍视频在线| 一区二区三区色| 国产精品久久中文字幕| 亚洲综合av一区二区三区| 欧美日韩的一区二区| 欧美熟妇精品一区二区| 制服丝袜日韩| 久久的精品视频| 色婷婷av国产精品| 六月丁香婷婷久久| 国产精品久久一区二区三区| 特黄特黄一级片| 亚洲最大的免费| 国产一区第一页| 欧美激情一区| 4k岛国日韩精品**专区| 日韩欧美国产免费播放| 日日狠狠久久偷偷四色综合免费| 亚洲国产精品一区二区久久hs| 一本精品一区二区三区| 亚洲欧美韩国综合色| 国产乱码精品一区二区三区卡| 日韩av资源| 亚洲女女做受ⅹxx高潮| 国产男女无遮挡| 玖玖精品一区| 一区二区三区精品99久久| 日本系列第一页| 麻豆视频观看网址久久| 色一区在线观看| 性做久久久久久免费观看欧美| 日韩欧美手机在线| av网站在线免费看推荐| 色婷婷av一区二区三区大白胸 | 老司机一区二区| 国产高清在线精品一区二区三区| eeuss影院www在线播放| 五月综合激情日本mⅴ| 亚洲高清视频免费| 精品黄色一级片| 91sa在线看| 亚洲成人中文字幕在线| 亚洲欧洲av在线| 欧美一级裸体视频| 婷婷亚洲成人| 亚州精品天堂中文字幕| a天堂视频在线| 国产精品福利一区二区三区| 国产麻花豆剧传媒精品mv在线| 丁香综合av| 爽爽爽爽爽爽爽成人免费观看| 好吊色在线视频| 91香蕉视频mp4| 中文字幕av一区| 90岁老太婆乱淫| 一本一道久久综合狠狠老精东影业| 91在线观看免费观看| 亚洲1卡2卡3卡4卡乱码精品| 日本韩国视频一区二区| 美女扒开腿免费视频| 欧美/亚洲一区| 亚洲一区二区中文| 激情影院在线观看| 9191精品国产综合久久久久久| 91无套直看片红桃在线观看| 奇米色一区二区| 五月天色一区| 九七电影院97理论片久久tvb| 一区三区二区视频| 中文字幕日本视频| 国产精品三级在线观看| 亚洲久久中文字幕| 色综合久久一区二区三区| 国产免费一区二区三区香蕉精| 超碰免费97在线观看| 在线观看免费视频综合| 熟女俱乐部一区二区视频在线| 亚欧美中日韩视频| 日本一区二区三区在线视频| 成人亚洲综合| 久久视频在线看| www.黄色一片| 亚洲成人在线免费| 欧美丰满少妇人妻精品| 免费日韩av片| 神马影院我不卡午夜| 日韩成人在线电影| 欧美成人免费观看| 后入内射欧美99二区视频| 精品福利樱桃av导航| 国产色视频一区二区三区qq号| 石原莉奈一区二区三区在线观看| 亚洲成人a**址| 国产精品一区免费在线 | 欧美精选午夜久久久乱码6080| 欧美日韩色视频| 波多野结衣精品在线| 日韩av在线综合| 国产精品久久久久久久久久10秀| 99视频在线免费观看| 蜜桃麻豆影像在线观看| 在线看日韩欧美| www.蜜臀av.com| 一本到不卡免费一区二区| 三上悠亚在线观看视频| 成人午夜电影小说| 任你操这里只有精品| 久久久久蜜桃| 久久99久久精品国产| 97久久网站| 午夜剧场成人观在线视频免费观看| 黄色美女网站在线观看| 日韩一区二区影院| 97人人澡人人爽人人模亚洲| 国产精品美女视频| 无码国产精品一区二区免费式直播| 丝袜美腿亚洲综合| 4444在线观看| 精品一区二区三| 国产富婆一区二区三区| 成人性片免费| 欧美一区二区三区四区在线| 99在线视频观看| 国产亚洲精品日韩| 成人精品在线播放| 欧美电影一区二区| 成人免费毛片男人用品| 亚洲一区在线看| 91无套直看片红桃在线观看| 99久久er热在这里只有精品15| 男人添女人下面免费视频| 亚洲理论在线| 国产激情片在线观看| 日韩精品影视| 欧美日韩大片一区二区三区| 538任你躁精品视频网免费| 国产精品视频一区二区高潮| 三妻四妾完整版在线观看电视剧 | 亚洲欧美se| 欧美高跟鞋交xxxxhd| 欧美性天天影视| 亚洲新中文字幕| 三区在线视频| 亚洲第一av网| 亚洲国产欧美另类| 538在线一区二区精品国产| 波多野结衣一二区| 岛国av一区二区三区| 国产性一乱一性一伧一色| 亚洲人成人一区二区在线观看| 亚洲精品成人无码| 91网页版在线| 免费看黄色aaaaaa 片| 99久久伊人网影院| 亚洲中文字幕无码一区| 粉嫩高潮美女一区二区三区| 熟妇无码乱子成人精品| 狠狠色丁香婷婷综合| 中文字幕中文在线| 蜜桃视频免费观看一区| 天天操天天爱天天爽| 日本美女一区二区三区| 狠狠操精品视频| 久久深夜福利| 天天操天天爽天天射| 日韩成人精品视频| 成人在线观看a| 亚洲欧美清纯在线制服| 亚洲爆乳无码专区| 丝袜美腿亚洲综合| 91小视频网站| 久久av中文字幕片| 久久久久久久高清| 国产精品1区2区| 91传媒理伦片在线观看| 成人黄色大片在线观看| 熟妇高潮一区二区| 99久久免费视频.com| 欧美亚洲免费高清在线观看 | 四虎成人永久免费视频| 同产精品九九九| 中文字幕国产在线观看| 色88888久久久久久影院按摩| 伊人久久中文字幕| 欧美剧在线免费观看网站| 国产欧美一级片| 欧美mv和日韩mv国产网站| 亚洲免费成人在线| 亚洲理论在线a中文字幕| 国产资源在线观看| 色吧影院999| 日韩经典av| 91精品国产精品| 成人四虎影院| eeuss一区二区三区| 日韩超碰人人爽人人做人人添| 欧美人与物videos另类| 亚洲成av人片乱码色午夜| 男人添女荫道口女人有什么感觉| 中日韩视频在线观看| 男女男精品视频站| 国产精品小仙女| 亚洲一区二区观看| 亚洲天堂福利av| 福利所第一导航| 色综合久久综合| 亚洲精品一区二区三| 熟女少妇一区二区三区| 高清久久精品| 91gao视频| 欧美午夜寂寞| 欧美成人蜜桃| 亚洲国产精品日韩专区av有中文| 极品粉嫩国产18尤物| 日韩电影网1区2区| 色欲欲www成人网站| 久久精品视频在线看| 极品盗摄国产盗摄合集| 欧美性猛交xxxx免费看漫画| 国产精品久久免费| 亚洲精品一区二区网址| 黄在线免费看| 国产mv久久久| 99久久香蕉| 一区二区三区四区| 国产九九精品| 成年人看片网站| 亚洲国产精品国自产拍av| 日本午夜小视频| 日韩视频一区二区在线观看| 国产露出视频在线观看| 国模叶桐国产精品一区| 国产成人视屏| 亚洲黄色成人久久久| 亚洲一区二区免费看| 4438x全国最大成人| 中文字幕在线一区免费| 高潮毛片又色又爽免费 | 精品一区二区免费视频| 男人网站在线观看| 亚洲女性喷水在线观看一区| 中文人妻熟女乱又乱精品| 亚洲国产美女精品久久久久∴| 国产视频中文字幕在线观看| 国产精品高潮视频| 亚洲av片在线观看| 亚洲国模精品一区| 三级资源在线| 91久久综合亚洲鲁鲁五月天| 成人精品天堂一区二区三区| 岳毛多又紧做起爽| 99精品久久久久久| 日韩精品国产一区二区| 精品久久久影院| 性欧美1819sex性高清大胸| 成人欧美在线观看| 97精品国产| 女人高潮一级片| 国产高清精品久久久久| 久久视频免费观看| 国产三级视频在线播放| 中文国产成人精品久久一| 欧美7777| 欧美日韩喷水| 久久综合伊人| 摸摸摸bbb毛毛毛片| 欧美亚洲综合在线| 粉嫩av在线播放| 国产精品久久久久久久久久ktv| 国产精品羞羞答答在线观看| 国产一区亚洲二区三区| 91麻豆国产福利精品| 国产精品久免费的黄网站| 日韩国产欧美精品一区二区三区| sm在线播放| 久久精品日韩精品| 麻豆亚洲精品| 内射毛片内射国产夫妻| 欧美婷婷六月丁香综合色| a√在线中文网新版址在线| 国产精品自产拍在线观看| 香蕉久久网站| 永久看看免费大片| 亚洲国产精品嫩草影院| 手机在线不卡av| 国产精品成人一区二区三区吃奶| 欧美日韩性在线观看| 亚洲久久中文字幕| 亚洲激情自拍视频| 手机看片一区二区三区| 国产aⅴ夜夜欢一区二区三区| 色婷婷综合网| 稀缺呦国内精品呦| 在线欧美日韩精品| 国精产品一区| 国产精品一区二区三区四区五区| 国产日韩欧美高清免费| 免费看的黄色录像| 日韩三级在线免费观看| 99riav视频在线观看| 欧美极品日韩| 国产一区二区免费看| 亚洲精品视频在线观看免费视频| 一区二区三区无码高清视频| 日本在线一区二区三区| 丰满爆乳一区二区三区| 中文字幕亚洲视频| 国产 欧美 自拍| 国产欧美韩国高清| 亚洲国产第一| 免费91在线观看| 亚洲第一免费网站| 国产一区影院| 日韩人妻精品无码一区二区三区| 亚洲欧美自拍偷拍色图| 十八禁一区二区三区| 成人av在线网址| 午夜在线观看免费一区|