欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

MySQL中MTR的概念

 更新時(shí)間:2020年11月10日 10:45:39   作者:AsiaYe  
這篇文章主要介紹了MySQL中MTR的概念,幫助大家更好的理解和使用MySQL數(shù)據(jù)庫(kù),感興趣的朋友可以了解下

    MTR全稱是Mini-Transaction,顧名思義,可以理解為"最小的事務(wù)",MySQL中把對(duì)底層頁(yè)面的一次原子訪問(wèn)的過(guò)程稱之為一個(gè)Mini-Transaction,這里的原子操作,指的是要么全部成功,要么全部失敗,不存在中間狀態(tài)。

    MTR主要是被用在寫undo log和redo log的場(chǎng)景下的。例如,我們要向一個(gè)B+樹(shù)索引中插入一條記錄,此時(shí)要么插入成功,要么插入失敗,這個(gè)過(guò)程就可以稱為一個(gè)MTR過(guò)程,這個(gè)過(guò)程中會(huì)產(chǎn)生一組redo log日志,這組日志在做MySQL的崩潰恢復(fù)的時(shí)候,是一個(gè)不可分割的整體。

    假如我們有一個(gè)事務(wù),事務(wù)中包含3條語(yǔ)句,那么MTR的概念圖如下:

Mini-Transaction一般遵循三條原則:

  • 1、the fix rules
  • 2、WAL
  • 3、force-log-at-commit

這里我們解釋下這三條原則:

1、the fix rules

解釋第一條規(guī)則之前,我們有必要了解下MySQL中的latch的概念,在MySQL中,latch是一種輕量級(jí)的鎖,與lock不同,它鎖定的時(shí)間特別短,在innodb中,latch又可以分為mutex(互斥量)和rwlock(讀寫鎖)2種,它的目的在于保證并發(fā)線程操作臨界資源的正確性。

理解了latch的概念,我們看看the fix rule規(guī)則:

修改一個(gè)數(shù)據(jù)頁(yè),需要獲得這個(gè)數(shù)據(jù)頁(yè)的x-latch;

訪問(wèn)一個(gè)頁(yè)是需要獲得s-latch或者x-latch;

持有該頁(yè)的latch直到修改或者訪問(wèn)該頁(yè)的操作完成才釋放

2、WAL

WAL技術(shù)想必大家比較熟悉,它是Innodb存儲(chǔ)引擎之所以支持崩潰恢復(fù)的根本,也就是持久化一個(gè)數(shù)據(jù)頁(yè)之前,需要將內(nèi)存中響應(yīng)的日志頁(yè)先持久化

3、force-log-at-commit

這條原則比較重要,它是指在事務(wù)提交的時(shí)候,其產(chǎn)生的所有MTR日志都要刷到持久化設(shè)備中,從而保證崩潰恢復(fù)的邏輯。

   之所以介紹MTR,是為了后續(xù)介紹MySQL8.0的redo log 優(yōu)化做準(zhǔn)備,在MySQL5.7中,mtr保證了事務(wù)內(nèi)部操作的原子性。當(dāng)用戶進(jìn)行操作的時(shí)候,會(huì)更新數(shù)據(jù)頁(yè),同時(shí)寫redo log,mtr是redo log的載體,存在每個(gè)連接會(huì)話的私有變量中。當(dāng)mtr提交時(shí),會(huì)將本地redo log拷貝到全局的log_buffer中,為了保證redo log的有序性,需要加鎖來(lái)訪問(wèn)log_buffer,這把鎖就是上面提到的mutex,在這個(gè)鎖保護(hù)下,除了要將本地日志拷貝到全局buffer,還需要將數(shù)據(jù)頁(yè)加入了flush_list,供后臺(tái)線程刷臟,輔助數(shù)據(jù)庫(kù)檢查點(diǎn)持續(xù)往前推進(jìn),所以這個(gè)鎖在舊版本的MySQL中競(jìng)爭(zhēng)非常激烈。MySQL8.0將這個(gè)問(wèn)題進(jìn)行了優(yōu)化,后面的文章中將著重分析。

以上就是MySQL中MTR的概念的詳細(xì)內(nèi)容,更多關(guān)于MySQL MTR的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • 通過(guò)代碼實(shí)例了解頁(yè)面置換算法原理

    通過(guò)代碼實(shí)例了解頁(yè)面置換算法原理

    這篇文章主要介紹了通過(guò)代碼實(shí)例了解頁(yè)面置換算法原理,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-08-08
  • MySQL億級(jí)數(shù)據(jù)平滑遷移雙寫方案實(shí)戰(zhàn)

    MySQL億級(jí)數(shù)據(jù)平滑遷移雙寫方案實(shí)戰(zhàn)

    預(yù)約業(yè)務(wù)與其他業(yè)務(wù)數(shù)據(jù)表存儲(chǔ)在同一個(gè)數(shù)據(jù)庫(kù),當(dāng)其他業(yè)務(wù)出現(xiàn)慢SQL等異常時(shí),會(huì)影響到預(yù)約業(yè)務(wù),為了提高系統(tǒng)穩(wěn)定性和數(shù)據(jù)隔離性,需要將預(yù)約數(shù)據(jù)表從原來(lái)的數(shù)據(jù)庫(kù)中遷移出來(lái),單獨(dú)建立數(shù)據(jù)庫(kù),涉及到的讀寫場(chǎng)景多,改造成本大,采用 Mybatis插件實(shí)現(xiàn)遷移所需的雙寫等功能
    2024-08-08
  • MySQL 元數(shù)據(jù)鎖及問(wèn)題排查的解決

    MySQL 元數(shù)據(jù)鎖及問(wèn)題排查的解決

    MySQL中的元數(shù)據(jù)鎖主要用于管理并發(fā)操作下的數(shù)據(jù)字典一致性,本文主要介紹了MySQL 元數(shù)據(jù)鎖及問(wèn)題排查的解決,具有一定的參考價(jià)值,感興趣的可以了解一下
    2024-09-09
  • MySQL數(shù)據(jù)庫(kù)事務(wù)transaction示例講解教程

    MySQL數(shù)據(jù)庫(kù)事務(wù)transaction示例講解教程

    這篇文章主要為大家介紹了MySQL數(shù)據(jù)庫(kù)事務(wù)transaction的示例講解教程,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步
    2021-10-10
  • MySQL是怎么保證主備一致的

    MySQL是怎么保證主備一致的

    大家知道 binlog 可以用來(lái)歸檔,也可以用來(lái)做主備同步,但它的內(nèi)容是什么樣的呢?為什么備庫(kù)執(zhí)行了 binlog 就可以跟主庫(kù)保持一致了呢,本文就詳細(xì)的介紹一下
    2021-09-09
  • MySQL常用的建表、添加字段、修改字段、添加索引SQL語(yǔ)句寫法總結(jié)

    MySQL常用的建表、添加字段、修改字段、添加索引SQL語(yǔ)句寫法總結(jié)

    這篇文章主要介紹了MySQL常用的建表、添加字段、修改字段、添加索引SQL語(yǔ)句寫法,總結(jié)分析了MySQL建表、編碼設(shè)置、字段添加、索引操作所涉及的SQL語(yǔ)句,需要的朋友可以參考下
    2017-05-05
  • 關(guān)于MySQL索引的深入解析

    關(guān)于MySQL索引的深入解析

    這篇文章主要給大家介紹了關(guān)于MySQL索引的深入解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用MySQL具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-11-11
  • master and slave have equal MySQL server ids

    master and slave have equal MySQL server ids

    Fatal error: The slave I/O thread stops because master and slave have equal MySQL server ids
    2013-07-07
  • mysqld-nt: Out of memory (Needed 1677720 bytes)解決方法

    mysqld-nt: Out of memory (Needed 1677720 bytes)解決方法

    這篇文章主要介紹了mysqld-nt: Out of memory (Needed 1677720 bytes)解決方法,需要的朋友可以參考下
    2014-12-12
  • MySQL高效導(dǎo)入多個(gè).sql文件方法詳解

    MySQL高效導(dǎo)入多個(gè).sql文件方法詳解

    MySQL有多種方法導(dǎo)入多個(gè).sql文件,常用的有兩個(gè)命令:mysql和source,如何提高導(dǎo)入速度,在導(dǎo)入大的sql文件時(shí),建議使用mysql命令
    2018-10-10

最新評(píng)論