為什么MySQL里有binlog和redolog?你知道他們的作用嘛

搞懂MySQL的redolog、binlog

為什么要redolog?

對于一般的理解而言,當(dāng)更新數(shù)據(jù)的時候,把數(shù)據(jù)寫入到磁盤就好了,為什么MySQL要先寫入redolog并更新內(nèi)存,在空閑的時候才再把redolog里的數(shù)據(jù)寫入磁盤呢?這里涉及到MySQL里經(jīng)常說到的WAL(Write-Ahead Logging)技術(shù),也就是先寫日志,因為寫日志是追加操作,只需要在磁盤上追加一條日志即可,而如果是直接將數(shù)據(jù)寫入磁盤,那么我們需要先找到原先數(shù)據(jù)存放在磁盤上的地址,然后再寫入。顯然直接寫日志效率更高,redolog有點像是磁盤的緩存,先把要寫入的數(shù)據(jù)放到redolog里,當(dāng)系統(tǒng)空閑或是redolog寫滿了的時候,再把redolog寫入磁盤。

redolog的特性

  • redolog是InnoDB引擎才有的。
  • redolog的大小是有限的,且是一個循環(huán)結(jié)構(gòu),有一個write_pos和一個checkpoint,當(dāng)write_pos追上checkpoint的時候,表示redolog寫滿了,這時MySQL必須將redolog里的內(nèi)容存儲到磁盤以給redolog騰出空間。
  • redolog里寫的是物理日志,所謂物理日志指的是里面記錄的是磁盤數(shù)據(jù)頁上面的變化。
  • redolog是保證MySQL crash-safe的重要因素。在MySQL崩潰后的恢復(fù),主要靠的就是redolog和binlog來對MySQL進行恢復(fù)的,保證數(shù)據(jù)的完整和一致。

為什么要binlog?

binlog是MySQL恢復(fù)數(shù)據(jù)以及做備份庫的重要依據(jù)。例如當(dāng)我們想把數(shù)據(jù)恢復(fù)到今天8點整的狀態(tài),這時候就要依賴binlog了,具體的操作流程是:

  1. 先建立備份庫
  2. 讀取MySQL的快照,如果我們每天0點做一次備份的話,那么就讀取今天0點的快照,把備份庫的數(shù)據(jù)先恢復(fù)到今天0點的狀態(tài)。
  3. 然后我們讀取binlog里從今天0點到8點的日志,執(zhí)行日志里的邏輯操作。
  4. 最后用備份庫替換掉原庫的數(shù)據(jù)。
    這樣就能將數(shù)據(jù)恢復(fù)到今天8點的狀態(tài)了。
    做備份庫的邏輯也是相似的,先讀取一個最近的快照,在這個快照的基礎(chǔ)上,讀取binlog。

binlog的特性

  • binlog是MySQL Server層的,因此不論什么引擎都可以使用binlog。
  • binlog的大小理論上是沒有限制的(只要磁盤足夠大),因為binlog就是一直追加寫邏輯操作日志,當(dāng)文件太大了,就換一個文件接著寫。
  • binlog存儲的是邏輯日志,也就是平常我們執(zhí)行的MySQL的語句。

重要的兩階段提交

當(dāng)我們更新數(shù)據(jù)時,兩階段提交的具體流程:

  • 更新操作先寫入redolog,這時候這條log的狀態(tài)是prepared狀態(tài)
  • 再將邏輯日志寫入binlog
  • 最后在binlog寫好之后,把redolog里的這條日志的狀態(tài)改為commit

為什么要兩階段提交?

我們試想一下,假設(shè)沒有兩階段提交,我們先寫redolog再寫binlog,或者是先寫binlog再寫redolog,會發(fā)生什么?
update tab set v=v+1 where id=1為例(假設(shè)v之前的值為0)

  • 先寫redolog,再寫binlog:如果在寫完redolog之后MySQL崩潰,這時候binlog還沒有寫,在MySQL恢復(fù)的時候,就會出現(xiàn)MySQL里v的值已經(jīng)是1了,而binlog里并沒有update這條語句,這樣如果我們要做數(shù)據(jù)備份,在備份的數(shù)據(jù)庫里v的值就還是0,這樣會導(dǎo)致數(shù)據(jù)的不一致。
  • 先寫binlog,再寫redolog:如果在寫完binlog之后,MySQL崩潰,這時候redolog還沒有寫,這樣在MySQL恢復(fù)后,就會出現(xiàn)MySQL里v的值還是0,可是binlog里有這條更新的log,也就意味著當(dāng)我們做備份庫的時候,備份庫里的v會是1,導(dǎo)致數(shù)據(jù)不一致。

那么兩階段提交又為什么能保證數(shù)據(jù)的一致性呢?
我們也對一些極端情況做一下分析:

  • 假設(shè)寫完redolog prepared之后,MySQL崩潰,這時候binlog沒有寫入,當(dāng)MySQL恢復(fù)的時候,發(fā)現(xiàn)redolog里有一條prepared的記錄,可是binlog里并沒有相關(guān)的日志,這時候MySQL會丟棄這條prepared日志,也就是說當(dāng)這條語句并沒有執(zhí)行成功,最終MySQL里v還是0,而binlog里也每有這條更新的日志。
  • 假設(shè)寫完binlog之后,在把redolog改為commit之前,MySQL崩潰,當(dāng)MySQL恢復(fù)的時候,發(fā)現(xiàn)redolog里有prepared的日志,若prepared事務(wù)在從Binlog中得到的提交事務(wù)列表中,則在InnoDB層提交此事務(wù),也就是說MySQL識別到這條prepared的redolog是有效的,這樣通過引擎查詢到的v值會是1,同時binlog里也有此事務(wù)的日志。
    正是這樣兩階段提交保證了數(shù)據(jù)的一致性。

兩階段提交在跨系統(tǒng)維持數(shù)據(jù)邏輯一致性時是很常用的方案,對于平常工作中處理到類似問題時具有啟發(fā)性。例如假設(shè)我們的數(shù)據(jù)庫是MySQL+redis來構(gòu)建的,存在一種需求是我們寫了MySQL之后,要去寫redis,同時我們希望這兩個操作具有一致性,也就是說我們希望他們要么都成功了,要么都失敗了,不要在MySQL里寫成功了,而在redis里寫失敗了,最終造成數(shù)據(jù)不一致。這種情況我們就可以考慮借鑒兩階段提交這個機制。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 227,797評論 6 531
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 98,179評論 3 414
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 175,628評論 0 373
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經(jīng)常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 62,642評論 1 309
  • 正文 為了忘掉前任,我火速辦了婚禮,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 71,444評論 6 405
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 54,948評論 1 321
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,040評論 3 440
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 42,185評論 0 287
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 48,717評論 1 333
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 40,602評論 3 354
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 42,794評論 1 369
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,316評論 5 358
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 44,045評論 3 347
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,418評論 0 26
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 35,671評論 1 281
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 51,414評論 3 390
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 47,750評論 2 370