MySQL的binlog是一種二進(jìn)制日志,記錄了數(shù)據(jù)庫(kù)的更改操作,包括插入、更新、刪除等操作。在主從復(fù)制的情況下,從庫(kù)會(huì)讀取主庫(kù)上的binlog信息,重放到從庫(kù)上,以保證主從庫(kù)數(shù)據(jù)的一致性。
在MySQL的binlog中,事件的順序非常重要,因?yàn)閺膸?kù)需要按照主庫(kù)上的操作順序重放binlog信息。如果從庫(kù)讀取binlog的順序與主庫(kù)不一致,就會(huì)導(dǎo)致從庫(kù)上的數(shù)據(jù)不一致。例如,如果從庫(kù)讀取了某個(gè)操作的undo日志,卻沒(méi)有讀取該操作的redo日志,那么從庫(kù)上的數(shù)據(jù)就會(huì)出現(xiàn)問(wèn)題。
為了保證binlog的順序,MySQL采用了兩種方式:
- 事務(wù)級(jí)別鎖定:MySQL在開(kāi)啟事務(wù)時(shí),會(huì)對(duì)表進(jìn)行鎖定,保證在整個(gè)事務(wù)期間,寫(xiě)操作的順序是固定的。
- 預(yù)寫(xiě)式日志(Write Ahead Logging):MySQL在對(duì)一個(gè)事務(wù)進(jìn)行寫(xiě)操作時(shí),先將這個(gè)操作記錄到redo日志中,表示這個(gè)操作已經(jīng)成功執(zhí)行;當(dāng)提交一個(gè)事務(wù)時(shí),MySQL會(huì)將這個(gè)事務(wù)記錄到binlog中,表示這個(gè)事務(wù)已經(jīng)執(zhí)行完畢。因此,在從庫(kù)重放binlog時(shí),可以保證先執(zhí)行redo日志,然后執(zhí)行binlog中的事務(wù)。
總的來(lái)說(shuō),MySQL的binlog保證了更改操作的順序,并且在主從復(fù)制過(guò)程中,也能保證從庫(kù)上的數(shù)據(jù)與主庫(kù)一致。