精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

MySQL redo log 的深度解析

數(shù)據(jù)庫 MySQL
重做日志使得MySQL在宕機(jī)情況下依舊可以redo log完成數(shù)據(jù)具備恢復(fù)能力, 從而保證數(shù)據(jù)完整性,本文將針對該日志進(jìn)行分析講解

redo log也就是所謂的重做日志,是innoDb存儲引擎獨有的日志,它使得MySQL在宕機(jī)情況下依舊可以redo log完成數(shù)據(jù)具備恢復(fù)能力, 從而保證數(shù)據(jù)完整性,本文將針對該日志進(jìn)行分析講解,希望對你有幫助。

1. redo log的作用

redo log是InnoDB存儲引擎獨有的日志,用于MySQL工作過程中崩潰或者宕機(jī)時進(jìn)行數(shù)據(jù)恢復(fù)的文件,從而保證數(shù)據(jù)的持久性以及完整性。

2. redo log是如何運(yùn)行工作的

我們都知道數(shù)據(jù)庫數(shù)據(jù)基本單位也是和操作系統(tǒng)一致的,都是以頁為單位,我們以MySQL數(shù)據(jù)查詢?yōu)槔瑸榱吮M可能減少IO次數(shù),MySQL在進(jìn)行數(shù)據(jù)查詢會優(yōu)先將數(shù)據(jù)查詢并存儲到Buffer Pool中,然后按照一定的調(diào)度規(guī)則將修改操作寫回磁盤中。

當(dāng)我們需要對數(shù)據(jù)修改操作之后,這個修改操作就會優(yōu)先被生成一個redo日志存放到redo log buffer中,最終就會被刷盤并寫入到redo log file中。

默認(rèn)情況下日志對應(yīng)的緩沖區(qū)大小為16M,這里面包括了redo.log的緩沖區(qū),該變量我們可以通過如下語句查看:

SHOW VARIABLES LIKE 'innodb_log_buffer_size';

對應(yīng)查詢結(jié)果如下:

Variable_name         |Value   |
----------------------+--------+
innodb_log_buffer_size|16777216|

redo log的刷盤時機(jī)

上文圖解的第四步提到了redo log刷盤的操作,當(dāng)符合以下幾種條件時,對應(yīng)redo log buffer會被刷盤持久化到磁盤中:

  • 事務(wù)提交:當(dāng)事務(wù)提交時,log buffer里redo log會按照innodb_flush_log_at_trx_commit的刷盤時機(jī)將數(shù)據(jù)持久化到磁盤中。
  • log buffer空間不足:log buffer中的redo log已經(jīng)占滿該緩沖區(qū)一半時,緩沖區(qū)數(shù)據(jù)就會被刷到磁盤中。
  • 事務(wù)日志緩沖區(qū)已滿:InnoDB使用一個事務(wù)日志緩沖區(qū)(transaction log buffer)存儲事務(wù)redo log的日志條目,當(dāng)該緩存區(qū)已滿時,就會觸發(fā)日志刷新將日志寫入磁盤中。
  • checkpoint:線程會定時執(zhí)行一個checkpoint,將buffer pool已經(jīng)刷盤對應(yīng)的redo.log設(shè)置為可被覆蓋(保證日志空間可以循環(huán)復(fù)用),這期間對應(yīng)的redo數(shù)據(jù)就會被寫入磁盤中。
  • 服務(wù)器關(guān)閉:MySQL服務(wù)正常關(guān)閉時,這些緩沖區(qū)的數(shù)據(jù)就會寫入到磁盤中。

redo log的刷盤策略

上文事務(wù)提交時提到一個刷盤策略的概念,實際上寫入磁盤的時機(jī)是由MySQL系統(tǒng)參數(shù)設(shè)置決定的,我們可以鍵入下面這條SQL查看innodb_flush_log_at_trx_commit這個參數(shù)的設(shè)定值:

SHOW VARIABLES LIKE 'innodb_flush_log_at_trx_commit';

以筆者的MySQL8為例,默認(rèn)情況下這個參數(shù)值為1:

當(dāng)這個值為0時,每次進(jìn)行修改寫入到redo log buffer,然后redo log buffer會將數(shù)據(jù)寫到page cache中,由log thread每個1s調(diào)用操作系統(tǒng)函數(shù)fsync將數(shù)據(jù)寫入到redo.file中。很可能因為服務(wù)器崩潰或者宕機(jī)導(dǎo)致丟失1s的數(shù)據(jù)。

1為默認(rèn)值,當(dāng)參數(shù)值設(shè)置為1時, 每次進(jìn)行修改操作后將數(shù)據(jù)寫入到redo log buffer中,一旦事務(wù)被提交,就會自動調(diào)用操作系統(tǒng)函數(shù)fsync將數(shù)據(jù)寫入的磁盤中的redo.file文件中。若設(shè)置為這個級別,當(dāng)服務(wù)器宕機(jī),若當(dāng)前事務(wù)沒有提交,這部分?jǐn)?shù)據(jù)丟失也無妨,事務(wù)提交的話,那么這個操作就會被寫到磁盤中,照樣可以恢復(fù)。

配置為2時,每當(dāng)事務(wù)提交后,redo log就會刷入內(nèi)核緩沖區(qū),這些數(shù)據(jù)具體何時刷盤則交由操作系統(tǒng)決定,這種情況在MySQL宕機(jī)情況下不會造成數(shù)據(jù)丟失,一旦操作系統(tǒng)崩潰則可能會造成內(nèi)核緩沖區(qū)的redo log數(shù)據(jù)丟失,導(dǎo)致進(jìn)行數(shù)據(jù)備份還原時丟失一部分?jǐn)?shù)據(jù):

redo log的日志文件組

redo log并不是單指一個文件,它是由一組日志文件構(gòu)成的,如下圖所示,這些文件大小都是一樣的,寫入操作時依次從從1開始寫,文件1寫滿了,就將數(shù)據(jù)寫到文件2,最后寫到文件4。

redolog通過write pos標(biāo)記當(dāng)前寫入的位置,每次完成寫入write pos標(biāo)志位后移,一旦write pos和checkpoint相遇時就說明文件滿了,此時innodb就會通過讓checkpoint往后移進(jìn)行一些空間數(shù)據(jù)擦除,以此來保證一個足夠空間容納新數(shù)據(jù)。

為什么InnoDB不直接將數(shù)據(jù)寫入磁盤

頁是操作系統(tǒng)的基本單位,一頁差不多16kb,而我們每次操作的數(shù)據(jù)可能也就x byte,為了x byte的數(shù)據(jù)操作將一頁的數(shù)據(jù)進(jìn)行同步持久化實在有些大材小用了,所以通過redo log buffer記錄修改內(nèi)容,通過刷盤策略進(jìn)行數(shù)據(jù)輸盤更新,由此提升數(shù)據(jù)庫的并發(fā)能力,

bin.log和redo.log對應(yīng)的二階段提交

經(jīng)常有讀者面試被問道的為什么我有了undo log,你還需要bin log呢?而且這兩個日志我到底要先寫哪個才能保證主從數(shù)據(jù)庫的一致性呢?

對此我們不妨用反正法來說明:

假設(shè)我們先寫bin.log,當(dāng)事務(wù)提交后bin.log寫入成功,結(jié)果再寫redo.log期間,數(shù)據(jù)庫掛了。重啟恢復(fù)后,主數(shù)據(jù)庫工具redo.log恢復(fù)到bin log寫入前的樣子,而從數(shù)據(jù)庫在工具bin.log進(jìn)行數(shù)據(jù)同步時發(fā)現(xiàn)bin log有一條寫入操作,最終從數(shù)據(jù)庫比主數(shù)據(jù)庫多了一條數(shù)據(jù)。

我們再假設(shè)寫redo log,假設(shè)事務(wù)執(zhí)行期間我們就寫了redo log,在事務(wù)提交之后寫bin log數(shù)據(jù)庫掛了,我們重啟數(shù)據(jù)庫后主主庫恢復(fù)。主庫根據(jù)redo log進(jìn)行災(zāi)備恢復(fù),將我們更新的數(shù)據(jù)同時恢復(fù)回來,而從庫根據(jù)bin log進(jìn)行數(shù)據(jù)同步時,并沒有察覺到主庫剛剛寫入的數(shù)據(jù),這就導(dǎo)致了從庫比主庫少了一條數(shù)據(jù)。

所以MySQL設(shè)計者提出了二階段提交的概念,整體步驟為:

  • 在事務(wù)開始時,先寫redo-log(prepare)。
  • 事務(wù)提交時,再寫bin log。
  • 事務(wù)提交成功,再寫redo-log(commit)。

有了這樣一個整體步驟我們不妨用兩種情況來舉個例子演示一下二階段提交如何保證數(shù)據(jù)一致性。

假設(shè)我們有一張user表,這張表只有id、name兩個字段。我們執(zhí)行如下SQL:

update user set name='aa' where id=1;

假如我們在redo.log提交時數(shù)據(jù)庫宕機(jī),二階段是如何保證數(shù)據(jù)一致性的呢?

首先數(shù)據(jù)庫重啟恢復(fù),然后主庫發(fā)現(xiàn)redo.log日志處于prepare而且bin.log也沒有寫入,所以一切恢復(fù)到之前的樣子(事務(wù)回滾),而從庫對此無感,同步時也是同步成操作失敗之前的樣子,一切風(fēng)平浪靜:

假如我們bin.log進(jìn)行commit成功之后數(shù)據(jù)庫宕機(jī),二階段提交是如何保證數(shù)據(jù)庫一致性的呢?還是老規(guī)矩:

  • 數(shù)據(jù)庫重啟恢復(fù),然后主庫發(fā)現(xiàn)bin.log有個commit成功的數(shù)據(jù)(事務(wù)是完整的)
  • 然redo.log處于prepare階段,但是我們還是可以根據(jù)情況推斷出有個當(dāng)前主庫有個commit成功的事務(wù),所以redo.log會根據(jù)bin.log將redo.log設(shè)置為commit
  • 從庫已根據(jù)主庫的bin.log發(fā)現(xiàn)有新增一條新數(shù)據(jù),由此同步一條更新數(shù)據(jù),雙方都有了一條新數(shù)據(jù),數(shù)據(jù)庫一致性由此保證:

責(zé)任編輯:趙寧寧 來源: 寫代碼的SharkChili
相關(guān)推薦

2021-01-26 13:47:08

MySQL存儲數(shù)據(jù)

2024-06-11 00:00:02

MySQL數(shù)據(jù)庫系統(tǒng)

2020-08-20 12:10:42

MySQL日志數(shù)據(jù)庫

2021-07-28 08:32:03

MySQLRedo存儲

2024-05-30 08:03:17

2024-03-14 14:18:58

MySQL業(yè)務(wù)設(shè)計事務(wù)

2024-05-28 00:10:00

JavaMySQL數(shù)據(jù)庫

2021-10-04 09:23:30

Redo日志內(nèi)存

2025-06-06 07:02:43

2022-08-26 10:11:26

MySQL數(shù)據(jù)庫

2025-01-15 13:19:09

MySQL日志事務(wù)

2023-11-23 13:17:39

MySQL?數(shù)據(jù)庫

2010-01-06 09:30:51

Oracle Redo

2021-05-28 11:18:50

MySQLbin logredo log

2024-12-16 00:00:05

MySQL二進(jìn)制數(shù)據(jù)

2025-10-09 02:22:00

MySQLMVCC庫存數(shù)量

2025-08-11 09:08:41

2019-05-06 15:27:48

Oracle數(shù)據(jù)庫數(shù)據(jù)

2010-11-23 11:36:15

MySQL創(chuàng)建關(guān)聯(lián)表

2010-11-25 09:37:14

MySQL查詢緩存機(jī)制
點贊
收藏

51CTO技術(shù)棧公眾號

91情侣在线视频| 原创国产精品91| 欧美亚洲日本一区二区三区| 高清毛片aaaaaaaaa片| 国产精品综合| 日韩在线高清视频| 大乳护士喂奶hd| 国产精品xxx| 亚洲综合色视频| 日韩国产欧美一区| 精品区在线观看| 巨乳诱惑日韩免费av| 久久五月天色综合| 免费无码一区二区三区| 国产精品久久乐| 无码av中文一区二区三区桃花岛| 日日夜夜精品网站| 内射后入在线观看一区| 免费精品视频在线| 91精品国产乱码久久久久久久久| 日本不卡一区视频| 亚洲+变态+欧美+另类+精品| 91精品国产91久久久久久一区二区| 成人免费在线网| 老司机福利在线视频| 99久久精品免费看国产免费软件| 国产精品欧美激情| 欧美在线观看不卡| 狠狠爱成人网| 久久影院免费观看| 大胸美女被爆操| 曰本一区二区三区视频| 欧美变态tickling挠脚心| 在线免费观看视频黄| 麻豆mv在线看| 亚洲综合男人的天堂| 影音先锋亚洲视频| yes4444视频在线观看| 91在线精品秘密一区二区| 亚洲淫片在线视频| 亚洲一区中文字幕永久在线| 久久久人人人| 91po在线观看91精品国产性色| 亚洲av无码一区二区三区在线| 怕怕欧美视频免费大全| 亚洲国产成人爱av在线播放| 潘金莲一级淫片aaaaaaa| 欧美一级在线| 精品视频色一区| 亚欧在线免费观看| 欧美日韩五码| 在线免费观看日本欧美| 国产免费视频传媒| 日韩在线影院| 欧美亚洲高清一区二区三区不卡| 哪个网站能看毛片| 特黄毛片在线观看| 欧美丝袜第一区| 男人靠女人免费视频网站| а√天堂中文在线资源8| 亚洲永久精品大片| www.av毛片| 涩涩视频在线播放| 欧美性猛交xxxxx免费看| www一区二区www免费| 色是在线视频| 91福利在线免费观看| 成人午夜激情av| 四虎精品在线观看| 日韩一区二区三区在线视频| 日批视频免费看| 国产精品极品| 精品亚洲va在线va天堂资源站| 一级性生活毛片| 欧美日韩色图| 久久在线免费观看视频| 国产亚洲精品久久777777| 在线国产精品一区| 国产成人精品一区二区三区| 伊人久久国产精品| 国产成人精品亚洲日本在线桃色| 国产精品日韩一区二区| 午夜av免费观看| 日本一区二区成人在线| 在线观看成人免费| 国产理论在线| 在线观看日韩av先锋影音电影院| 亚洲精品视频三区| 999国产精品一区| 日韩风俗一区 二区| 黄色三级生活片| 欧美激情成人在线| 欧美一级在线亚洲天堂| 中文字幕免费视频观看| 国产老女人精品毛片久久| 精品蜜桃传媒| 男人在线资源站| 亚洲成人一区在线| 污版视频在线观看| 亚洲国产中文在线| 亚洲色图50p| 青青草手机视频在线观看| 亚洲伊人网站| 亚洲sss综合天堂久久| 天堂资源中文在线| 亚洲欧美一区二区久久 | 欧美私人网站| 天天综合色天天综合色h| 自拍偷拍21p| 欧美尿孔扩张虐视频| yw.139尤物在线精品视频| 好吊妞视频一区二区三区| 久久精品国产免费| 久久久福利视频| av毛片在线播放| 欧美性受xxxx黑人xyx| 国产午夜在线一区二区三区| 欧美aaaa视频| 日本免费在线精品| 欧美一区二区三区激情| 亚洲欧美在线观看| 天堂中文视频在线| 天堂综合网久久| 久久久久久久久综合| 97成人免费视频| 欧美国产在线观看| 免费黄色日本网站| 北条麻妃一区二区三区在线观看| 日韩在线播放一区| 中文字幕乱码中文字幕| 337p粉嫩大胆噜噜噜噜噜91av| 91免费版看片| gogo大尺度成人免费视频| 国产亚洲精品久久久久动| 天天干天天干天天操| www.欧美色图| a级免费在线观看| 精品亚洲二区| 久久艹在线视频| 国产精品视频在线观看免费| 中文字幕+乱码+中文字幕一区| 欧美黄色免费影院| 亚洲区小说区| 欧美中文在线观看| 四虎在线观看| 五月激情综合网| 99久久免费看精品国产一区| 在线欧美亚洲| 国产欧美日韩伦理| 国产资源在线观看入口av| 精品国产一区二区国模嫣然| 久久免费视频6| 盗摄精品av一区二区三区| 日韩精品久久一区二区| 亚洲高清999| 久久久久久久影院| 日本精品一区二区在线观看| 亚洲成人777| 麻豆精品国产传媒av| 国产精品日本| 欧美日韩免费高清| 国产精品99久久久久久董美香| 中文字幕亚洲一区二区三区五十路 | 精品一区在线| 国产精品久在线观看| 在线免费看av| 91精品国产麻豆| 欧美日韩成人免费观看| 成人听书哪个软件好| 国产精品12345| 国产麻豆精品久久| 国产中文日韩欧美| a级网站在线播放| 精品99久久久久久| 婷婷激情五月综合| 亚洲三级电影网站| 麻豆精品国产传媒av| 老司机精品导航| 一区二区不卡在线视频 午夜欧美不卡' | 668精品在线视频| 成人精品一区二区三区校园激情| 欧美日本精品一区二区三区| 国产av 一区二区三区| 成人精品电影在线观看| 亚洲精品中文字幕无码蜜桃| 久久久久国产精品| 精品无人区一区二区三区竹菊 | 欧美精品导航| 麻豆视频成人| 国产精品麻豆| 欧美一级视频一区二区| 黄色免费在线观看网站| 亚洲精品suv精品一区二区| 日本三级一区二区三区| 亚洲日穴在线视频| 亚洲国产无码精品| 国产suv精品一区二区三区| 国产视频一区二区三区在线播放| 综合av在线| 日韩影视精品| 精品亚洲自拍| 成人欧美在线观看| 黑人巨大精品| 欧美国产日本高清在线| yourporn在线观看视频| 亚洲激情视频网| 91在线公开视频| 色拍拍在线精品视频8848| 18岁成人毛片| 国产精品久久国产精麻豆99网站 | 最好看的日本字幕mv视频大全| 亚洲激情五月婷婷| 国产在视频线精品视频| 99久久777色| 不卡的一区二区| 久久99日本精品| 97在线免费公开视频| 国内成人在线| 一区二区精品在线| 精品成av人一区二区三区| 国产精品入口免费| 日韩免费成人| 国产在线视频不卡| 免费观看成人性生生活片 | 欧美片第1页| 97精品免费视频| 青青在线视频| 不卡av日日日| 毛片免费不卡| 日韩中文字幕网址| 精品99又大又爽又硬少妇毛片| 日韩免费观看高清完整版在线观看| 中文字幕在线观看国产| 日韩欧美亚洲范冰冰与中字| 日韩毛片在线播放| 亚洲国产成人av| 青娱乐av在线| 一区二区三区毛片| 日本老熟俱乐部h0930| 亚洲色欲色欲www在线观看| 少妇高潮在线观看| 亚洲欧洲精品一区二区精品久久久 | 国产二级片在线观看| 亚洲精品孕妇| av动漫在线看| 亚洲一区观看| 国产女女做受ⅹxx高潮| 裸体一区二区| 免费国产成人av| 日本在线不卡一区| 五月婷婷六月丁香激情| 久久99精品久久只有精品| 天天摸天天舔天天操| 久久精品国产一区二区三| 一级黄色录像在线观看| 加勒比av一区二区| 永久看看免费大片| 成人性视频免费网站| 亚洲天堂美女视频| 久久奇米777| 林心如三级全黄裸体| 中文字幕一区三区| 欧美成欧美va| 亚洲h精品动漫在线观看| 亚洲精品男人天堂| 欧美在线999| 国产毛片毛片毛片毛片| 日韩午夜精品视频| 天堂在线资源8| 亚洲另类激情图| 在线观看av的网站| 九九热这里只有精品6| 国产在线xxx| 日本人成精品视频在线| 国产黄色一区| 成人在线视频电影| 曰本一区二区三区视频| 免费久久久久久| 狠狠综合久久| 91蝌蚪视频在线观看| 国产一区二区在线观看免费| 国产国语老龄妇女a片| 久久人人超碰精品| 放荡的美妇在线播放| 五月天中文字幕一区二区| 亚洲国产成人精品女人久久| 91麻豆精品国产91久久久使用方法 | 欧美一区二区三区四区在线观看地址| 欧美色图一区| 欧美亚洲色图视频| 日韩av在线发布| 任你躁av一区二区三区| 日本一区二区视频在线| 久久久久久av无码免费网站| 91久久精品日日躁夜夜躁欧美| www.热久久| 中文字幕日韩在线视频| 99在线视频影院| 成人a在线视频| 久久av综合| 污污污污污污www网站免费| 免费人成黄页网站在线一区二区| 特级特黄刘亦菲aaa级| 国产精品久久久久久亚洲毛片 | 91一区二区三区| 国产精品探花在线观看| 青草网在线观看| 狠狠色狠狠色合久久伊人| 中文字幕国产专区| 亚洲午夜在线视频| 国产又黄又粗又硬| 亚洲人成在线观看网站高清| 国产黄色大片在线观看| 91久久精品国产91久久| 精品黄色一级片| 国模吧无码一区二区三区| 国产激情视频一区二区三区欧美| 精品日韩在线视频| 欧美色图在线视频| 内射后入在线观看一区| 九九九久久久久久| 粉嫩av国产一区二区三区| 亚洲高清视频在线观看| 久久精品午夜| 久久久久麻豆v国产精华液好用吗| 亚洲欧美二区三区| 一女二男一黄一片| 国产一区二区三区在线播放免费观看| 激情黄产视频在线免费观看| av噜噜色噜噜久久| 中文字幕一区二区三区在线视频| 亚洲人视频在线| 日本一区二区不卡视频| 免费黄色片视频| 亚洲美女又黄又爽在线观看| 亚洲一二三四| 免费亚洲一区二区| 一区二区黄色| 无码人妻精品一区二区三区温州| 亚洲图片一区二区| 亚洲乱码国产乱码精品精软件| 久久国产精品久久久久久| 成人豆花视频| 裸体大乳女做爰69| 国内精品视频666| 国产一二三四区| 日韩手机在线导航| 免费在线看污片| 国产精品一区免费观看| 亚洲精品免费观看| 特大黑人巨人吊xxxx| 色综合天天性综合| av在线免费播放网站| 国产精品日韩欧美大师| 欧美艳星介绍134位艳星| 成人亚洲精品777777大片| 亚洲国产精品v| 91亚洲国产成人久久精品麻豆 | 可以直接看的黄色网址| 日韩欧美国产不卡| 漫画在线观看av| 日韩一区国产在线观看| 久久国产精品72免费观看| 国产精品视频一区二区三| 日韩视频在线一区二区| 91资源在线观看| 日韩av不卡在线播放| 麻豆91在线播放免费| 久久国产精品波多野结衣av| 亚洲国产精品专区久久| 亚洲天堂一区二区| 一区二区三区免费看| 粉嫩绯色av一区二区在线观看| 国产在线视频二区| 亚洲欧美日韩精品久久奇米色影视| 欧美成人app| 免费网站永久免费观看| 99久久免费精品高清特色大片| 中文字幕+乱码+中文乱码91| 久久中文精品视频| 欧亚精品一区| 五月婷婷六月丁香激情| 一区二区三区不卡视频| 免费在线毛片| 91在线播放国产| 国产日韩一区二区三区在线| 成人在线一级片| 欧美成人精品二区三区99精品| 日韩精品美女| 男女啪啪的视频| 久久综合久久综合久久| 国产一区二区三区四区视频| 97热在线精品视频在线观看| 欧美亚洲高清| 娇妻高潮浓精白浆xxⅹ| 欧美私人免费视频| 第一福利在线视频| 中文字幕欧美日韩一区二区三区| www.成人在线| 97精品人妻一区二区三区在线|