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

MySQL中MTR的概念

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

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

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

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

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

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

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

1、the fix rules

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

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

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

訪問一個頁是需要獲得s-latch或者x-latch;

持有該頁的latch直到修改或者訪問該頁的操作完成才釋放

2、WAL

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

3、force-log-at-commit

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

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

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

相關(guān)文章

  • 通過代碼實例了解頁面置換算法原理

    通過代碼實例了解頁面置換算法原理

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

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

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

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

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

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

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

    MySQL是怎么保證主備一致的

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

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

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

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

    這篇文章主要給大家介紹了關(guān)于MySQL索引的深入解析,文中通過示例代碼介紹的非常詳細,對大家學習或者使用MySQL具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧
    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高效導入多個.sql文件方法詳解

    MySQL高效導入多個.sql文件方法詳解

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

最新評論