亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

MySQL 日志相關知識總結

 更新時間:2021年02月02日 16:04:00   作者:Joe學習生活  
這篇文章主要介紹了MySQL 日志相關知識總結,幫助大家更好的理解和實用MySQL,感興趣的朋友可以了解下

數(shù)據(jù)庫中用于存儲數(shù)據(jù)的文件稱為data file,日志文件稱為log file。此外,如果每次讀寫都是直接訪問磁盤,性能很差,所以數(shù)據(jù)庫是有緩存的,數(shù)據(jù)緩存是data buffer,日志緩存log buffer。

sql執(zhí)行順序

當我們執(zhí)行一條更新語句時,比如 update table set c=c+1 where id = 2,執(zhí)行順序如下:

  • 執(zhí)行器通過存儲引擎獲取id=2的行記錄。如果id=2的行記錄所在的數(shù)據(jù)頁已經(jīng)在內(nèi)存中,則直接返回;否則,需要從磁盤讀取數(shù)據(jù)
  • 執(zhí)行器拿到返回的行數(shù)據(jù),把字段c的值+1,得到新的行數(shù)據(jù),然后調(diào)用存儲引擎接口寫入行數(shù)據(jù)
  • 引擎把這行數(shù)據(jù)更新到內(nèi)存,同時將這個更新操作記錄到redo log里面,此時redo log處于prepare狀態(tài)。然后告訴執(zhí)行器執(zhí)行完成,隨時可以提交事務
  • 執(zhí)行器生成這個操作的bin log,并把bin log寫入磁盤
  • 執(zhí)行器調(diào)用引擎的提交事務接口,引擎把剛剛寫入的redo log改成commit狀態(tài),更新完成

補充:MySQL的基本存儲結構是頁(記錄都存在頁里邊),所以MySQL是先把這條記錄所在的頁找到,然后把該頁加載到內(nèi)存中,再修改對應的記錄。

bin log

是什么

bin log稱為歸檔日志、二進制日志,屬于MySQL Server層面的,用于記錄數(shù)據(jù)庫表結構和表數(shù)據(jù)的變更,可以簡單理解為存儲每條變更的sql語句,比如insert、delete、update(當然,不僅是sql,還有事務id,執(zhí)行時間等等)。

什么時候產(chǎn)生

事務提交的時候,一次性將事務中的sql語句按照一定格式記錄到bin log

有什么用

主要有兩個作用:主從復制和恢復數(shù)據(jù)

  • 目前大部分數(shù)據(jù)庫架構都是一主多從,從服務器通過訪問主服務器的bin log,保證數(shù)據(jù)一致性
  • bin log記錄數(shù)據(jù)庫的變更,可以通過它恢復數(shù)據(jù)

什么時候落盤

區(qū)分innodb_flush_log_at_trx_commit和sync_binlog

​ 二進制日志取決于sync_binlog參數(shù)

  • 0:事務提交后,由操作系統(tǒng)決定什么時候把緩存刷新到磁盤(性能最好,安全性最差)
  • 1:每提交一次事務,調(diào)用一次fsync將緩存寫入到磁盤(安全性最好,性能最差)
  • n:當提交n次事務后,調(diào)用一次fsync將緩存寫入到磁盤

文件記錄模式

bin log有三種文件記錄模式,分別是row、statement、mixed

  • row(row-based replication,PBR):記錄每一行數(shù)據(jù)的修改情況

優(yōu)點:能夠清楚記錄每行數(shù)據(jù)修改細節(jié),能夠完全保證主從數(shù)據(jù)一致性
缺點:批量操作時會產(chǎn)生大量的日志,比如alter table

  • statement:記錄每條修改數(shù)據(jù)的sql,可認為sql語句復制

優(yōu)點:日志數(shù)據(jù)量小,減少磁盤IO,提高存儲和恢復速度
缺點:在某些情況下會出現(xiàn)主從不一致,比如sql語句中包含**now()**等函數(shù)

  • mixed:上面兩種模式的混合,MySQL會根據(jù)sql語句選擇寫入模式,一般使用statement模式保存bin log,對于statement模式無法復制的操作,使用row模式保存bin log。

redo log

是什么

redo log稱為重做日志,屬于InnoDB存儲引擎層的日志,記錄物理頁的修改信息,而不是某一行或幾行修改成什么樣

什么時候產(chǎn)生

事務開始,就會寫入redo log。redo log寫入到磁盤并不是隨著事務提交才寫入,而是在事務執(zhí)行過程中,就已經(jīng)寫入到磁盤

有什么用

可用于恢復數(shù)據(jù)。redo log是在事務開始后就寫入到磁盤,且是順序IO,寫入速度較快。如果服務器突然掉電,InnoDB引擎會使用redo log把數(shù)據(jù)庫恢復到掉電前的時刻,保證數(shù)據(jù)的完整性

什么時候落盤

InnoDB先把日志寫到緩沖區(qū)(log buffer),然后再把日志從log buffer刷到os buffer,最后調(diào)用文件系統(tǒng)的fsync函數(shù)將日志刷新到磁盤。重做日志寫入時機由參數(shù)innodb_flush_log_at_trx_commit決定

  • 0:每秒一次,把log buffer寫入os buffer,并調(diào)用fsync刷到磁盤
  • 1:每次提交事務時,把log buffer寫入os buffer,并調(diào)用fsync刷到磁盤
  • 2:每次提交事務時,只是寫入到os buffer,然后每秒一次調(diào)用fsync將日志刷新到磁盤

一般取值為2,因為即使MySQL宕機,數(shù)據(jù)也沒有丟失。只有整個服務器掛了,才損失1秒的數(shù)據(jù)

bin log VS redo log

看了以上的介紹,感覺bin log和redo log很像,都是記錄數(shù)據(jù)變更,可用于恢復。其實,它們還是有明顯區(qū)別的。

  • bin log屬于MySQL Server層面的,redo log屬于InnoDB存儲引擎層面
  • bin log是邏輯日志,記錄的是sql語句的原始邏輯;redo log是物理日志,記錄的是物理頁面更新的內(nèi)容
  • bin log是追加寫,文件達到限制后會更換下個文件,不會覆蓋;redo log是循環(huán)寫,文件大小固定,寫滿就重頭開始寫,覆蓋原來的內(nèi)容
  • bin log作用是主從復制和恢復數(shù)據(jù),當數(shù)據(jù)庫被刪除、或者從庫同步主庫數(shù)據(jù)時,由于bin log記錄變更數(shù)據(jù)的sql,所以可通過bin log恢復。而redo log作用是持久化,當發(fā)生服務器宕機或者掉電等情況,數(shù)據(jù)丟失,可以通過redo log恢復。
  • bin log是提交事務時才寫入磁盤,而redo log在開啟事務時,就開始寫入到磁盤

如果整個數(shù)據(jù)庫被刪除,可以通過redo log恢復嗎?

不行!因為redo log側重點是保存某次事務的數(shù)據(jù)變更,當內(nèi)存中的數(shù)據(jù)刷到磁盤后,redo log的數(shù)據(jù)其實已經(jīng)沒有參考價值。此外,redo log會覆蓋歷史數(shù)據(jù),也不可能通過它來恢復所有數(shù)據(jù)。

undo log

詳細分析MySQL事務日志

是什么

undo log稱為回滾日志,屬于InnoDB存儲引擎層,是邏輯日志,記錄每行數(shù)據(jù)。當我們變更數(shù)據(jù)時,就會產(chǎn)生undo log,可以認為insert一條數(shù)據(jù),undo log會記錄一條對應的delete日志,反之亦然。

什么時候產(chǎn)生

在事務開始前,將當前版本生成undo log

有什么用

主要作用:提供回滾和多版本并發(fā)控制(MVCC)

  • 回滾:當需要rollback時,從undo log的邏輯記錄讀取相應的內(nèi)容進行回滾
  • MVCC:undo log記錄中存儲的是舊版本數(shù)據(jù),當一個事務需要讀取數(shù)據(jù)時,會順著undo鏈找到滿足其可見性的記錄

以上就是MySQL 日志相關知識總結的詳細內(nèi)容,更多關于MySQL 日志的資料請關注腳本之家其它相關文章!

相關文章

  • centos下mysql主從同步快速設置步驟分享

    centos下mysql主從同步快速設置步驟分享

    記錄一個比較簡便的mysql的主從同步設置步驟,方便日后使用。
    2012-06-06
  • MySQL 使用規(guī)范總結

    MySQL 使用規(guī)范總結

    MySQL已經(jīng)成為世界上最受歡迎的數(shù)據(jù)庫管理系統(tǒng)之一,無論是用在小型開發(fā)項目上,還是用在構建那較大型的網(wǎng)站,MySQL都用實力證明了自己是一個穩(wěn)定、可靠、快速、可信的系統(tǒng),足以勝任任何數(shù)據(jù)存儲業(yè)務的需要。本文總結了MySQL的使用規(guī)范
    2020-09-09
  • mysql 5.7.24 安裝配置方法圖文教程

    mysql 5.7.24 安裝配置方法圖文教程

    這篇文章主要為大家詳細介紹了mysql 5.7.24 安裝配置方法圖文教程,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-11-11
  • MySQL更新,刪除操作分享

    MySQL更新,刪除操作分享

    這篇文章主要介紹了MySQL更新,刪除操作分享,文章根據(jù)MySQL的更新刪除命令的相關資料展開詳細的介紹,需要的小伙伴可以參考一下,希望對你有所幫助
    2022-03-03
  • MySQL 性能優(yōu)化的最佳20多條經(jīng)驗分享

    MySQL 性能優(yōu)化的最佳20多條經(jīng)驗分享

    今天,數(shù)據(jù)庫的操作越來越成為整個應用的性能瓶頸了,這點對于Web應用尤其明顯。關于數(shù)據(jù)庫的性能,這并不只是DBA才需要擔心的事,而這更是我們程序員需要去關注的事情。
    2010-07-07
  • mysql 查詢數(shù)據(jù)庫中的存儲過程與函數(shù)的語句

    mysql 查詢數(shù)據(jù)庫中的存儲過程與函數(shù)的語句

    mysql 查詢數(shù)據(jù)庫中的存儲過程與函數(shù)的語句,需要的朋友可以參考下。
    2011-05-05
  • bitronix 連接 MySQL 出現(xiàn)MySQLSyntaxErrorException 的解決方法

    bitronix 連接 MySQL 出現(xiàn)MySQLSyntaxErrorException 的解決方法

    這篇文章主要介紹了bitronix 連接 MySQL 出現(xiàn)MySQLSyntaxErrorException 的解決方法的相關資料,需要的朋友可以參考下
    2017-04-04
  • mysql之觸發(fā)器使用

    mysql之觸發(fā)器使用

    這篇文章主要介紹了mysql之觸發(fā)器使用方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2017-09-09
  • net?start?mysql服務名無效的三種解決方法

    net?start?mysql服務名無效的三種解決方法

    這篇文章主要介紹了net?start?mysql服務名無效的三種解決方法,通過圖文結合的方式講解的非常詳細,對大家的學習或工作有一定的幫助,需要的朋友可以參考下
    2024-08-08
  • MySQL 導入慢的解決方法

    MySQL 導入慢的解決方法

    MySQL導出的SQL語句在導入時有可能會非常非常慢,在導出時合理使用幾個參數(shù),可以大大加快導 入的速度。
    2010-12-12

最新評論