欧美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è)計了 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í)例的,建議初始化時做好評估。可以適當(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的幾種分頁方式,你知道幾種方式

    MySQL的幾種分頁方式,你知道幾種方式

    這篇文章主要介紹了MySQL的幾種分頁方式,需要的朋友可以參考下
    2023-06-06
  • 遠(yuǎn)程連接mysql錯誤代碼1130的解決方法

    遠(yuǎn)程連接mysql錯誤代碼1130的解決方法

    這篇文章主要介紹了遠(yuǎn)程連接mysql錯誤代碼1130的解決方法,非常不錯,具有參考借鑒價值,需要的朋友可以參考下
    2016-12-12
  • Window10下mysql 5.7.21 安裝配置方法圖文教程

    Window10下mysql 5.7.21 安裝配置方法圖文教程

    這篇文章主要為大家詳細(xì)介紹了Window10下mysql 5.7.21 安裝配置方法圖文教程,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-09-09
  • MySQL的查詢計劃中ken_len的值計算方法

    MySQL的查詢計劃中ken_len的值計算方法

    本文首先介紹了MySQL的查詢計劃中ken_len的含義;然后介紹了key_len的計算方法;最后通過一個偽造的例子,來說明如何通過key_len來查看聯(lián)合索引有多少列被使用
    2017-02-02
  • mysql8.0.11 winx64安裝配置教程

    mysql8.0.11 winx64安裝配置教程

    這篇文章主要為大家詳細(xì)介紹了mysql8.0.11 winx64安裝配置教程,文中安裝步驟介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-10-10
  • 簡單整理MySQL的日志操作命令

    簡單整理MySQL的日志操作命令

    這篇文章主要介紹了MySQL的日志操作命令,其中重點(diǎn)講述了MySQL的日志刪除方法,需要的朋友可以參考下
    2015-12-12
  • MySQL 如何限制一張表的記錄數(shù)

    MySQL 如何限制一張表的記錄數(shù)

    能否控制單表在一個固定的記錄數(shù),比如說1W條,超過不讓插入新記錄或者說直接拋出錯誤?關(guān)于這個問題,沒有一個簡化的答案,比如執(zhí)行一條命令或者說簡單設(shè)置一個參數(shù)都不能完美解決。接下來便介紹MySQL 如何限制一張表的記錄數(shù)來給出一些可選解決方案
    2021-09-09
  • MySQL Union合并查詢數(shù)據(jù)及表別名、字段別名用法分析

    MySQL Union合并查詢數(shù)據(jù)及表別名、字段別名用法分析

    這篇文章主要介紹了MySQL Union合并查詢數(shù)據(jù)及表別名、字段別名用法,結(jié)合實(shí)例形式較為詳細(xì)的分析了mysql使用Union合并連接查詢數(shù)據(jù)以及使用as實(shí)現(xiàn)表別名與字段別名操作,需要的朋友可以參考下
    2018-06-06
  • IntelliJ?IDEA?2024與MySQL?8連接以及driver問題解決辦法

    IntelliJ?IDEA?2024與MySQL?8連接以及driver問題解決辦法

    在IDE開發(fā)工具中也是可以使用mysql的,下面這篇文章主要給大家介紹了關(guān)于IntelliJ?IDEA?2024與MySQL?8連接以及driver問題解決辦法,文中通過圖文介紹的非常詳細(xì),需要的朋友可以參考下
    2024-09-09
  • Mysql使用全文索引(FullText?index)的實(shí)例代碼

    Mysql使用全文索引(FullText?index)的實(shí)例代碼

    使用索引時數(shù)據(jù)庫性能優(yōu)化的必備技能之一,下面這篇文章主要給大家介紹了關(guān)于Mysql使用全文索引(FullText?index)的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-04-04

最新評論