国产成人自拍一区-国产成人宗合-国产成人综合久久精品红-国产成人综合美国十次-国产成人综合欧美精品久久-国产成人综合日韩精品无

信息薈萃
    你的位置:首頁 > 信息薈萃

    突然停電了,我的數(shù)據(jù)還沒保存到數(shù)據(jù)庫……

    來源:譽澄智能 2021/1/5 8:53:47??????點擊:

    最近看到全國各地都在“拉閘限電”,嚇的我趕緊登上后臺服務(wù)器,看了看MySQL數(shù)據(jù)庫是否有問題,還好一切如常,也沒聽說北京有停電通知,好歹松了一口氣。

    微信圖片_20210105084913.jpg

    忽然想到一個問題,萬一數(shù)據(jù)庫正在執(zhí)行寫入操作,突然斷電了,會是怎么樣的呢?


    從MySQL V5.5開始,InnoDB成為了默認的存儲引擎。InnoDB中將頁作為磁盤管理的最小單位,數(shù)據(jù)校驗和數(shù)據(jù)寫入到磁盤都是以頁為單位操作的,通常情況下默認每個頁的大小為16KB。但由于文件系統(tǒng)對數(shù)據(jù)頁(16KB)的寫入多數(shù)情況下都不是原子操作,意味著當(dāng)服務(wù)器斷電時可能只寫了部分數(shù)據(jù)。


    一個數(shù)據(jù)頁的大小是16K,假設(shè)在把內(nèi)存中的臟頁(頁中有記錄被更新過)寫到磁盤時,寫了2K突然掉電,則前2K數(shù)據(jù)是新的,后14K是舊的,那么磁盤中的這個數(shù)據(jù)頁就是不完整的,是一個壞掉的數(shù)據(jù)頁。


    可能有經(jīng)驗的DBA會想到,如果發(fā)生寫失效,可以利用redo log進行恢復(fù)。


    這也許能夠解決部分問題,但redo log中記錄的是對頁的物理操作,redo log只能加上舊的、校檢完整的數(shù)據(jù)頁恢復(fù)一個臟塊,不能修復(fù)壞掉的數(shù)據(jù)頁。如果數(shù)據(jù)頁本身已經(jīng)發(fā)生了損壞,再對其進行重做是沒有意義的。

    那么就沒有其它辦法了嗎?當(dāng)然不是!這個時候double write就閃亮登場了。


    開啟了Double write(兩次寫/雙寫)后,在將內(nèi)存中的臟頁寫入到磁盤之前,會先保存該頁的副本,當(dāng)磁盤中的數(shù)據(jù)頁壞掉時,可以利用副本來還原該頁,再執(zhí)行重做,這就完美的解決了redo log無法修復(fù)壞頁的問題啦。


    Double write由兩部分組成,一部分是內(nèi)存中的double write緩存,共有128個頁(2MB);另一部分是磁盤上共享表空間中連續(xù)的128個頁(2MB)。


    下面我們來看一下將數(shù)據(jù)頁寫入磁盤的過程:

    1 拷貝:當(dāng)一系列機制觸發(fā)數(shù)據(jù)頁緩沖池中的臟頁(圖中黃色塊)刷新時,并不直接寫入磁盤數(shù)據(jù)文件中,而是先拷貝到內(nèi)存中的double write緩存中;

    2 順序?qū)懀?/span>接著將double write緩存區(qū)中的數(shù)據(jù)分兩次順序?qū)懭氲酱疟P的共享表空間中,每次寫入1MB。共享表空間中的double write頁是連續(xù)存儲的,采用順序?qū)懙姆绞侥軌蚝苎杆俚耐瓿蓪懟夭僮鳎_銷較小。

    3 離散寫:將double write緩存區(qū)中的臟頁數(shù)據(jù)寫入到實際的各個表空間文件。當(dāng)臟頁里的數(shù)據(jù)完全寫回磁盤后,即可將double write中的頁標(biāo)記為可覆蓋。


    如果在將臟頁刷新回磁盤的過程中發(fā)生崩潰,在恢復(fù)時,InnoDB存儲引擎可以從共享表空間中的double write中找到該頁的最近的一個副本,將其復(fù)制到表空間文件,再利用redo log進行重做,就完成了恢復(fù)過程。


    因存在副本,媽媽再也不用擔(dān)心我的電腦突然斷電了!


    有人可能會問,在寫redo log的時候是否需要double write支持呢?


    答案是不需要的,因為redo log在往磁盤中記錄信息的時候是以512字節(jié)為單位進行寫入的,而磁盤IO的最小單位恰巧也是512字節(jié),那么就無所謂數(shù)據(jù)損壞啦。


    有人可能會覺得開啟double write會帶來性能的損耗,其實呢,內(nèi)存中的double write緩存對應(yīng)的磁盤共享表空間的文件是連續(xù)存儲的,寫入時是順序?qū)憽m樞驅(qū)懙男阅芊浅8撸晕奚稽c性能來保證數(shù)據(jù)頁的完整是非常有必要的!


    主站蜘蛛池模板: 揄拍成人国产精品视频| 东京热一精品无码av| 久久久久国产精品人妻aⅴ果冻 | 精品无码国产自产拍在线观看蜜 | 欧美精品videosex性欧美| 国产又粗又大又黄| 超碰国产精品久久国产精品99| 一本清日本在线视频精品| 亚洲国产成人高清影视| 日本一区视频在线观看免费| 久久伊人精品一区二区三区介绍| 国产一区二区四区在线观看| 99热精品毛片全部国产无缓冲| 激情航班h版在线观看| 99久久精品国产综合| 五月婷婷开心中文字幕| 国产天美传媒性色av| 久久亚洲a片com人成| 久久久久久九九99精品| 久久99精品久久久久久水蜜桃| 大色综合色综合网站| 成人一区二区免费视频| 亚洲小说区图片区色综合网| 四虎国产精品永久地址入口| 手机看片日韩欧美人妻一区二区三区| 免费1级a做爰片观看| 国产精品视频一区二区亚瑟| 中文字幕无码毛片免费看| 国产福利日本一区二区三区| 日本三级欧美三级人妇视频| 国精产品一区一区三区有限在线 | 无人妻码一区二区三| 久久麻豆成人精品av| 国 精品一区二区三区| 国产自产v一区二区三区c| 成年女人永久免费看片| 全黄激性性视频| 欧洲精品码一区二区三区| 日本精品久久久久中文字幕| 好了av四色综合无码 | 中文字幕在线亚洲二区|