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

詳解MySQL 重做日志(redo log)與回滾日志(undo logo)

 更新時間:2020年08月30日 11:56:05   作者:MySQL技術(shù)  
這篇文章主要介紹了MySQL redo與undo日志的相關(guān)資料,幫助大家更好的理解和學(xué)習(xí)MySQL,感興趣的朋友可以了解下

前言:

前面文章講述了 MySQL 系統(tǒng)中常見的幾種日志,其實(shí)還有事務(wù)相關(guān)日志 redo log 和 undo log 沒有介紹。相對于其他幾種日志而言, redo log 和 undo log 是更加神秘,難以觀測的。本篇文章將主要介紹這兩類事務(wù)日志的作用及運(yùn)維方法。

1.重做日志(redo log)

我們都知道,事務(wù)的四大特性里面有一個是 持久性 ,具體來說就是只要事務(wù)提交成功,那么對數(shù)據(jù)庫做的修改就被永久保存下來了,不可能因?yàn)槿魏卧蛟倩氐皆瓉淼臓顟B(tài)。那么 MySQL 是如何保證一致性的呢?最簡單的做法是在每次事務(wù)提交的時候,將該事務(wù)涉及修改的數(shù)據(jù)頁全部刷新到磁盤中。但是這么做會有嚴(yán)重的性能問題,主要體現(xiàn)在兩個方面:

  • 因?yàn)?Innodb 是以頁為單位進(jìn)行磁盤交互的,而一個事務(wù)很可能只修改一個數(shù)據(jù)頁里面的幾個字節(jié),這個時候?qū)⑼暾臄?shù)據(jù)頁刷到磁盤的話,太浪費(fèi)資源了。
  • 一個事務(wù)可能涉及修改多個數(shù)據(jù)頁,并且這些數(shù)據(jù)頁在物理上并不連續(xù),使用隨機(jī) IO 寫入性能太差。

因此 MySQL 設(shè)計(jì)了 redo log ,具體來說就是只記錄事務(wù)對數(shù)據(jù)頁做了哪些修改,這樣就能完美地解決性能問題了(相對而言文件更小并且是順序IO)。

redo log 包括兩部分:一個是內(nèi)存中的日志緩沖(redo log buffer),另一個是磁盤上的日志文件(redo log file)。MySQL 每執(zhí)行一條 DML 語句,先將記錄寫入 redo log buffer ,后續(xù)某個時間點(diǎn)再一次性將多個操作記錄寫到 redo log file 。

默認(rèn)情況下,redo log 在磁盤上由名為 ib_logfile0 和 ib_logfile1 的兩個物理文件展示。redo log 相關(guān)參數(shù)簡單介紹如下:

  • innodb_log_files_in_group:redo log 文件的個數(shù),命名方式如:ib_logfile0,iblogfile1... iblogfilen。默認(rèn)2個,最大100個。
  • innodb_log_file_size:單個 redo log 文件設(shè)置大小,默認(rèn)值為 48M,最大值為512G,注意最大值指的是整個 redo log 系列文件之和,即(innodb_log_files_in_group * innodb_log_file_size )不能大于最大值512G。
  • innodb_log_group_home_dir:指定 redo log 文件組所在的路徑,默認(rèn)./ ,表示在數(shù)據(jù)庫的數(shù)據(jù)目錄下。
  • innodb_log_buffer_size:redo log buffer 大小,默認(rèn)16M。延遲事務(wù)日志寫入磁盤,把 redo log 放到該緩沖區(qū),然后根據(jù) innodb_flush_log_at_trx_commit 參數(shù)的設(shè)置,再把日志從 buffer 中 flush 到磁盤中。
  • innodb_flush_log_at_trx_commit:控制 redo log 刷新到磁盤的策略,默認(rèn)為1。值為1,每次 commit 都會把 redo log 從 redo log buffer 寫入到 system ,并 fsync 刷新到磁盤文件中。值為2,每次事務(wù)提交時 MySQL 會把日志從 redo log buffer 寫入到 system ,但只寫入到 file system buffer,由系統(tǒng)內(nèi)部來 fsync 到磁盤文件。如果數(shù)據(jù)庫實(shí)例 crash ,不會丟失 redo log,但是如果服務(wù)器 crash,由于 file system buffer 還來不及 fsync 到磁盤文件,所以會丟失這一部分的數(shù)據(jù)。值為0,表示事務(wù)提交時不進(jìn)行寫入 redo log 操作,這個操作僅在 master thread 中完成,而在 master thread 中每1秒進(jìn)行一次重做日志的 fsync 操作,因此實(shí)例 crash 最多丟失1秒鐘內(nèi)的事務(wù)。

更改 redo log 及其 buffer 大小是需要重啟數(shù)據(jù)庫實(shí)例的,建議初始化時做好評估??梢赃m當(dāng)加大 redo log 組數(shù)和大小,特別是你的數(shù)據(jù)庫實(shí)例更新比較頻繁的情況下。但也不推薦 redo log 設(shè)置過大。

2.回滾日志(undo log)

undo log 主要用于保證數(shù)據(jù)的原子性,保存了事務(wù)發(fā)生之前的數(shù)據(jù)的一個版本,可以用于回滾。比如一條 INSERT 語句,對應(yīng)一條 DELETE 的 undo log ,對于每個 UPDATE 語句,對應(yīng)一條相反的 UPDATE 的 undo log ,這樣在發(fā)生錯誤時,就能回滾到事務(wù)之前的數(shù)據(jù)狀態(tài)。同時,undo log 也是 MVCC (多版本并發(fā)控制) 實(shí)現(xiàn)的關(guān)鍵。

MySQL 5.7 版本中,undo log 默認(rèn)存放在共享表空間 ibdata 中。也可以在初始化時通過配置參數(shù)改成獨(dú)立的文件,簡單介紹幾個 undo log 相關(guān)參數(shù):

  • innodb_max_undo_log_size:控制最大 undo tablespace 文件的大小,當(dāng)啟動了innodb_undo_log_truncate 時,undo tablespace 超過 innodb_max_undo_log_size 閥值時才會去嘗試truncate。該值默認(rèn)大小為1G,truncate后的大小默認(rèn)為10M。
  • innodb_undo_tablespaces:設(shè)置 undo 獨(dú)立表空間個數(shù),范圍為0-128,5.7版本默認(rèn)為0,0表示不開啟獨(dú)立undo表空間。該參數(shù)只能在最開始初始化 MySQL 實(shí)例的時候指定。
  • innodb_undo_directory:設(shè)置 undo 表空間的存放目錄,默認(rèn)數(shù)據(jù)目錄。
  • innodb_undo_log_truncate:設(shè)置 undo 表空間是否自動截斷回收。該參數(shù)生效的前提是,已設(shè)置獨(dú)立表空間且獨(dú)立表空間個數(shù)大于等于2個。

undo log 相關(guān)參數(shù)一般很少改動。MySQL 8.0 默認(rèn)啟用了獨(dú)立表空間,可能 undo log 表空間的大小設(shè)置更靈活些。

總結(jié):

本篇文章主要介紹了 redo log 及 undo log 的作用和相關(guān)參數(shù)設(shè)置,文章寫的比較匆忙,如有錯誤,可以留言指出。關(guān)于這兩類日志更深層次的內(nèi)容,可能筆者功力還不到,未能寫到更加透徹。好了,MySQL 相關(guān)日志的兩篇文章已經(jīng)寫完了,希望各位能學(xué)到一點(diǎn)知識。

相關(guān)文章

  • MySQL慢查詢?nèi)罩局械腖ock_time由來解析

    MySQL慢查詢?nèi)罩局械腖ock_time由來解析

    這篇文章主要為大家介紹了慢查詢?nèi)罩局蠰ock_time的由來解析,以及Lock_time?包含哪些鎖等待時間、以及是怎么計(jì)算得到的,有需要的朋友可以借鑒參考下,希望能夠有所幫助
    2023-06-06
  • mysql5.5 master-slave(Replication)配置方法

    mysql5.5 master-slave(Replication)配置方法

    mysql5.5 master-slave(Replication)配置方法,需要的朋友可以參考下。
    2011-08-08
  • 淺談SQLite時間函數(shù)的使用說明與總結(jié)分析

    淺談SQLite時間函數(shù)的使用說明與總結(jié)分析

    本篇文章是對SQLite時間函數(shù)的使用進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下
    2013-05-05
  • mysql數(shù)據(jù)插入覆蓋和時間戳的問題及解決

    mysql數(shù)據(jù)插入覆蓋和時間戳的問題及解決

    這篇文章主要介紹了mysql數(shù)據(jù)插入覆蓋和時間戳的問題及解決,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-03-03
  • MySQL查詢條件常見用法詳解

    MySQL查詢條件常見用法詳解

    這篇文章主要介紹了MySQL查詢條件常見用法,結(jié)合實(shí)例形式總結(jié)分析了MySQL常見的各類查詢條件與簡單使用方法,需要的朋友可以參考下
    2019-11-11
  • MySQL與PHP的基礎(chǔ)與應(yīng)用專題之?dāng)?shù)據(jù)查詢

    MySQL與PHP的基礎(chǔ)與應(yīng)用專題之?dāng)?shù)據(jù)查詢

    MySQL是一個關(guān)系型數(shù)據(jù)庫管理系統(tǒng),由瑞典MySQL?AB?公司開發(fā),屬于?Oracle?旗下產(chǎn)品。MySQL?是最流行的關(guān)系型數(shù)據(jù)庫管理系統(tǒng)之一,本系列將帶你掌握php與mysql的基礎(chǔ)應(yīng)用,本篇從數(shù)據(jù)的查詢開始
    2022-02-02
  • mysql表的清空、刪除和修改操作詳解

    mysql表的清空、刪除和修改操作詳解

    這篇文章主要詳細(xì)介紹了mysql表的清空、刪除和修改操作的方法,以及一些常用的mysql的常用操作,非常的簡單實(shí)用,有需要的可以參考下
    2014-09-09
  • 圖文詳解MySQL中的主鍵與事務(wù)

    圖文詳解MySQL中的主鍵與事務(wù)

    這篇文章主要給大家介紹了關(guān)于MySQL中主鍵與事務(wù)的相關(guān)資料,主鍵與事務(wù)是我們使用mysql中經(jīng)常遇到的,文中通過圖文以及實(shí)例代碼介紹的很詳細(xì),需要的朋友可以參考下
    2021-05-05
  • mysql limit分頁優(yōu)化方法分享

    mysql limit分頁優(yōu)化方法分享

    MySQL的優(yōu)化是非常重要的。其他最常用也最需要優(yōu)化的就是limit。MySQL的limit給分頁帶來了極大的方便,但數(shù)據(jù)量一大的時候,limit的性能就急劇下降。
    2011-04-04
  • MySQL高級操作指令匯總

    MySQL高級操作指令匯總

    本文給大家?guī)淼氖荕ySQL高級操作指令代碼,羅列的很詳細(xì)并且附帶有例子,對大家的學(xué)習(xí)將會很有用,建議收藏以防丟失,需要的朋友可以參考下
    2022-01-01

最新評論