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

搞懂MySQL的redolog座舍、binlog

為什么要redolog?

對(duì)于一般的理解而言陨帆,當(dāng)更新數(shù)據(jù)的時(shí)候曲秉,把數(shù)據(jù)寫入到磁盤就好了采蚀,為什么MySQL要先寫入redolog并更新內(nèi)存,在空閑的時(shí)候才再把redolog里的數(shù)據(jù)寫入磁盤呢承二?這里涉及到MySQL里經(jīng)常說到的WAL(Write-Ahead Logging)技術(shù)榆鼠,也就是先寫日志,因?yàn)閷懭罩臼亲芳硬僮骱ヰ恍枰诖疟P上追加一條日志即可妆够,而如果是直接將數(shù)據(jù)寫入磁盤,那么我們需要先找到原先數(shù)據(jù)存放在磁盤上的地址读虏,然后再寫入责静。顯然直接寫日志效率更高,redolog有點(diǎn)像是磁盤的緩存盖桥,先把要寫入的數(shù)據(jù)放到redolog里灾螃,當(dāng)系統(tǒng)空閑或是redolog寫滿了的時(shí)候,再把redolog寫入磁盤揩徊。

redolog的特性

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

為什么要binlog?

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

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

binlog的特性

  • binlog是MySQL Server層的箍铲,因此不論什么引擎都可以使用binlog雇卷。
  • binlog的大小理論上是沒有限制的(只要磁盤足夠大),因?yàn)閎inlog就是一直追加寫邏輯操作日志颠猴,當(dāng)文件太大了关划,就換一個(gè)文件接著寫。
  • binlog存儲(chǔ)的是邏輯日志翘瓮,也就是平常我們執(zhí)行的MySQL的語句贮折。

重要的兩階段提交

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

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

為什么要兩階段提交?

我們?cè)囅胍幌潞强福僭O(shè)沒有兩階段提交每庆,我們先寫redolog再寫binlog,或者是先寫binlog再寫redolog今穿,會(huì)發(fā)生什么缤灵?
update tab set v=v+1 where id=1為例(假設(shè)v之前的值為0)

  • 先寫redolog,再寫binlog:如果在寫完redolog之后MySQL崩潰蓝晒,這時(shí)候binlog還沒有寫腮出,在MySQL恢復(fù)的時(shí)候,就會(huì)出現(xiàn)MySQL里v的值已經(jīng)是1了拔创,而binlog里并沒有update這條語句利诺,這樣如果我們要做數(shù)據(jù)備份,在備份的數(shù)據(jù)庫里v的值就還是0剩燥,這樣會(huì)導(dǎo)致數(shù)據(jù)的不一致慢逾。
  • 先寫binlog,再寫redolog:如果在寫完binlog之后灭红,MySQL崩潰侣滩,這時(shí)候redolog還沒有寫,這樣在MySQL恢復(fù)后变擒,就會(huì)出現(xiàn)MySQL里v的值還是0君珠,可是binlog里有這條更新的log,也就意味著當(dāng)我們做備份庫的時(shí)候娇斑,備份庫里的v會(huì)是1策添,導(dǎo)致數(shù)據(jù)不一致材部。

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

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

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

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末塞琼,一起剝皮案震驚了整個(gè)濱河市菠净,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖毅往,帶你破解...
    沈念sama閱讀 221,695評(píng)論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件牵咙,死亡現(xiàn)場離奇詭異,居然都是意外死亡攀唯,警方通過查閱死者的電腦和手機(jī)霜大,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,569評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來革答,“玉大人,你說我怎么就攤上這事曙强〔泄眨” “怎么了?”我有些...
    開封第一講書人閱讀 168,130評(píng)論 0 360
  • 文/不壞的土叔 我叫張陵碟嘴,是天一觀的道長溪食。 經(jīng)常有香客問我,道長娜扇,這世上最難降的妖魔是什么错沃? 我笑而不...
    開封第一講書人閱讀 59,648評(píng)論 1 297
  • 正文 為了忘掉前任,我火速辦了婚禮雀瓢,結(jié)果婚禮上枢析,老公的妹妹穿的比我還像新娘。我一直安慰自己刃麸,他們只是感情好醒叁,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,655評(píng)論 6 397
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著泊业,像睡著了一般把沼。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上吁伺,一...
    開封第一講書人閱讀 52,268評(píng)論 1 309
  • 那天饮睬,我揣著相機(jī)與錄音,去河邊找鬼篮奄。 笑死捆愁,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的宦搬。 我是一名探鬼主播牙瓢,決...
    沈念sama閱讀 40,835評(píng)論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼间校!你這毒婦竟也來了矾克?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,740評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤憔足,失蹤者是張志新(化名)和其女友劉穎胁附,沒想到半個(gè)月后酒繁,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 46,286評(píng)論 1 318
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡控妻,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,375評(píng)論 3 340
  • 正文 我和宋清朗相戀三年州袒,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片弓候。...
    茶點(diǎn)故事閱讀 40,505評(píng)論 1 352
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡郎哭,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出菇存,到底是詐尸還是另有隱情夸研,我是刑警寧澤,帶...
    沈念sama閱讀 36,185評(píng)論 5 350
  • 正文 年R本政府宣布依鸥,位于F島的核電站亥至,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏贱迟。R本人自食惡果不足惜姐扮,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,873評(píng)論 3 333
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望衣吠。 院中可真熱鬧茶敏,春花似錦、人聲如沸蒸播。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,357評(píng)論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽袍榆。三九已至胀屿,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間包雀,已是汗流浹背宿崭。 一陣腳步聲響...
    開封第一講書人閱讀 33,466評(píng)論 1 272
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留才写,地道東北人葡兑。 一個(gè)月前我還...
    沈念sama閱讀 48,921評(píng)論 3 376
  • 正文 我出身青樓,卻偏偏與公主長得像赞草,于是被迫代替她去往敵國和親讹堤。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,515評(píng)論 2 359