濮阳杆衣贸易有限公司

主頁(yè) > 知識(shí)庫(kù) > MySQL 日志相關(guān)知識(shí)總結(jié)

MySQL 日志相關(guān)知識(shí)總結(jié)

熱門標(biāo)簽:外呼系統(tǒng)打電話上限是多少 曲靖移動(dòng)外呼系統(tǒng)公司 武漢網(wǎng)絡(luò)外呼系統(tǒng)服務(wù)商 電話外呼系統(tǒng)改號(hào) 百應(yīng)電話機(jī)器人優(yōu)勢(shì) 南昌三維地圖標(biāo)注 怎樣在地圖標(biāo)注銷售區(qū)域 地圖標(biāo)注費(fèi)用是多少 啥是企業(yè)400電話辦理

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

sql執(zhí)行順序

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

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

補(bǔ)充:MySQL的基本存儲(chǔ)結(jié)構(gòu)是頁(yè)(記錄都存在頁(yè)里邊),所以MySQL是先把這條記錄所在的頁(yè)找到,然后把該頁(yè)加載到內(nèi)存中,再修改對(duì)應(yīng)的記錄。

bin log

是什么

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

什么時(shí)候產(chǎn)生

事務(wù)提交的時(shí)候,一次性將事務(wù)中的sql語(yǔ)句按照一定格式記錄到bin log

有什么用

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

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

什么時(shí)候落盤

區(qū)分innodb_flush_log_at_trx_commit和sync_binlog

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

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

文件記錄模式

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

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

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

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

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

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

redo log

是什么

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

什么時(shí)候產(chǎn)生

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

有什么用

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

什么時(shí)候落盤

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

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

一般取值為2,因?yàn)榧词筂ySQL宕機(jī),數(shù)據(jù)也沒(méi)有丟失。只有整個(gè)服務(wù)器掛了,才損失1秒的數(shù)據(jù)

bin log VS redo log

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

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

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

不行!因?yàn)閞edo log側(cè)重點(diǎn)是保存某次事務(wù)的數(shù)據(jù)變更,當(dāng)內(nèi)存中的數(shù)據(jù)刷到磁盤后,redo log的數(shù)據(jù)其實(shí)已經(jīng)沒(méi)有參考價(jià)值。此外,redo log會(huì)覆蓋歷史數(shù)據(jù),也不可能通過(guò)它來(lái)恢復(fù)所有數(shù)據(jù)。

undo log

詳細(xì)分析MySQL事務(wù)日志

是什么

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

什么時(shí)候產(chǎn)生

在事務(wù)開(kāi)始前,將當(dāng)前版本生成undo log

有什么用

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

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

以上就是MySQL 日志相關(guān)知識(shí)總結(jié)的詳細(xì)內(nèi)容,更多關(guān)于MySQL 日志的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

您可能感興趣的文章:
  • MySQL 一則慢日志監(jiān)控誤報(bào)的問(wèn)題分析與解決
  • MySQL慢查詢?nèi)罩镜淖饔煤烷_(kāi)啟
  • MySQL 慢查詢?nèi)罩镜拈_(kāi)啟與配置
  • 詳解監(jiān)聽(tīng)MySQL的binlog日志工具分析:Canal
  • 詳解MySQL 重做日志(redo log)與回滾日志(undo logo)
  • MySQL Aborted connection告警日志的分析
  • 詳解 Mysql 事務(wù)和Mysql 日志
  • 關(guān)于Anemometer圖形化顯示MySQL慢日志的工具搭建及使用的詳細(xì)介紹
  • MySQL5.7慢查詢?nèi)罩緯r(shí)間與系統(tǒng)時(shí)間差8小時(shí)原因詳解
  • mysql將bin-log日志文件轉(zhuǎn)為sql文件的方法

標(biāo)簽:滄州 甘南 吉林 荊州 黑河 資陽(yáng) 隨州 錦州

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《MySQL 日志相關(guān)知識(shí)總結(jié)》,本文關(guān)鍵詞  MySQL,日志,相關(guān),知識(shí),總結(jié),;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《MySQL 日志相關(guān)知識(shí)總結(jié)》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于MySQL 日志相關(guān)知識(shí)總結(jié)的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    宁都县| 武陟县| 定安县| 麦盖提县| 泉州市| 景德镇市| 南平市| 丹东市| 温宿县| 光泽县| 石楼县| 万源市| 延寿县| 五原县| 青铜峡市| 西和县| 潜江市| 韩城市| 浮梁县| 长沙县| 山东| 高安市| 日土县| 尤溪县| 金寨县| 霍邱县| 商城县| 伊川县| 太康县| 徐州市| 镇赉县| 东兰县| 济宁市| 阿拉善右旗| 岢岚县| 行唐县| 大关县| 江油市| 房产| 龙泉市| 衡南县|