MySQL三大日志

redo log

  • 作用:用于崩潰恢復(fù),保證數(shù)據(jù)持久性和完整性

  • 刷盤(pán)時(shí)機(jī):默認(rèn)每次事務(wù)提交都會(huì)進(jìn)行刷盤(pán)操作

  • 事務(wù)在更新數(shù)據(jù)的時(shí)候就會(huì)寫(xiě)redo log,只不過(guò)這時(shí)只寫(xiě)進(jìn)redo log buffer,不刷盤(pán)一旦崩了就丟失數(shù)據(jù)了,(后臺(tái)有每隔一秒刷一次盤(pán)的線程)

  • redo log在硬盤(pán)上是以日志文件組的多文件形式存儲(chǔ),而且多文件之間采用環(huán)形數(shù)組形式,從頭向尾寫(xiě)

bin log

作用:記錄表更新內(nèi)容,用于數(shù)據(jù)備份、主從同步數(shù)據(jù),保證數(shù)據(jù)一致性

寫(xiě)入機(jī)制:事務(wù)啟動(dòng),binlog先寫(xiě)進(jìn)緩存,事務(wù)提交的時(shí)候才會(huì)刷到磁盤(pán)中

兩階段提交

redo log(重做日志)讓InnoDB存儲(chǔ)引擎擁有了崩潰恢復(fù)能力。

binlog(歸檔日志)保證了MySQL集群架構(gòu)的數(shù)據(jù)一致性。

兩階段提交時(shí)為了保證兩個(gè)日志一致。

過(guò)程:在事務(wù)中,修改數(shù)據(jù),寫(xiě)入redo log(prepare階段),提交事務(wù),寫(xiě)入bin log,設(shè)置redo log(commit)階段。只要redo log(prepare階段)和bin log數(shù)據(jù)一致,事務(wù)提交就可以成功

undo log

用于回滾異常操作

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容