精品欧美一区二区三区在线观看 _久久久久国色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ù)棧公眾號

国产精品女人久久久久久| 亚洲男人在线| 欧美综合另类| 亚洲国产中文字幕| 成人免费高清完整版在线观看| 成人做爰www看视频软件| 免费黄色片视频| 国产精品中文字幕制服诱惑| 亚洲婷婷国产精品电影人久久| 456亚洲影院| 97精品人妻一区二区三区蜜桃| 午夜伦理福利在线| 国产99精品视频| 久久精品国产成人| 天天影视综合色| 蜜桃免费在线| 国产香蕉精品| 欧美亚洲国产一区二区三区va| 激情视频一区二区| 日本三级视频在线| 六月丁香久久丫| 黄色精品在线看| 成人在线观看91| 日韩久久精品视频| 香蕉综合视频| 日韩一区和二区| 最新欧美日韩亚洲| 国产一区二区三区四区视频| 天天综合精品| 精品国产乱码久久久久久牛牛| 一区二区精品视频| 国产精品久久欧美久久一区| 亚洲国产一区二区在线观看| 亚洲天堂成人在线视频| 嫩草av久久伊人妇女超级a| 国产中文在线| 精品中文av资源站在线观看| 久久资源免费视频| 亚洲色图欧美日韩| 国产精品色婷婷在线观看| 一区二区三区四区高清精品免费观看| 亚洲最大av网站| 国产午夜精品无码| 国产成人调教视频在线观看 | 9999精品成人免费毛片在线看 | 91久久久久久久久久久| 亚洲不卡在线播放| 99这里只有精品视频| 精品久久久久久| 97超碰在线人人| 精品美女视频在线观看免费软件 | 成年人网站免费在线观看| 欧美xo影院| 国产精品久久久久久久蜜臀| 欧美一级在线播放| 日韩精品一卡二卡| 日韩午夜免费视频| 亚洲午夜av电影| 97超碰人人爽| 超碰高清在线| 国产精品久久久久久久久免费相片 | www.日本在线观看| 亚洲黄色影院| 中文字幕国内精品| 午夜诱惑痒痒网| 青草在线视频| 国产日产欧美一区二区三区 | 亚洲国产一区二区三区网站| 疯狂做受xxxx欧美肥白少妇| 亚洲一区三区电影在线观看| 亚洲乱亚洲乱妇| 不卡一二三区首页| 国产色婷婷国产综合在线理论片a| 久久久久久久久久99| 少妇精品久久久一区二区| 91精品国产综合久久精品性色| 毛片在线播放视频| 麻豆视频在线观看免费网站| 91在线看国产| 99国产视频| 成人黄色激情视频| 亚洲电影成人| 不卡av电影院| 日本熟伦人妇xxxx| 丝袜国产日韩另类美女| 欧美激情综合亚洲一二区| 亚洲色图欧美色| 亚洲福利天堂| 亚洲国产精品久久91精品| 毛片毛片毛片毛片毛| av日韩在线播放| 国产亚洲精品高潮| 青青草国产在线观看| 国产伦精品一区二区三区视频| 夜夜躁日日躁狠狠久久88av| 人妻无码中文久久久久专区| 日韩在线成人| 日韩一区二区在线免费观看| 91精品又粗又猛又爽| 国产亚洲电影| 久久久久中文字幕2018| 五月天av网站| 亚洲午夜精品一区二区国产 | 女女色综合影院| 婷婷亚洲久悠悠色悠在线播放| 爱情岛论坛亚洲首页入口章节| 深夜av在线| 精品国产户外野外| 国产一级免费大片| 国产精品视频一区视频二区| 亚洲国产欧美一区二区三区同亚洲 | 国模套图日韩精品一区二区| 五月婷婷激情综合网| 97视频在线免费| 亚洲精品成人一区| 欧美一卡二卡三卡| 韩国女同性做爰三级| 国产91久久精品一区二区| 欧美xxxx18国产| 波多野结衣亚洲色图| 日韩成人一级片| 国产综合久久久久久| 青青免费在线视频| 国产欧美日韩在线看| 亚洲国内在线| 9191在线| 亚洲欧美偷拍卡通变态| 毛葺葺老太做受视频| 日韩精品导航| 一区二区三区www| 欧美三级一区二区三区| 久久性色av| 精品一区二区三区视频日产| 性欧美1819sex性高清大胸| 亚洲一区二区三区激情| 99热一区二区| 97久久综合区小说区图片区| 日韩在线观看视频免费| 国产盗摄x88av| 久色婷婷小香蕉久久| 91久久久在线| 免费网站看v片在线a| 欧美三级午夜理伦三级中视频| 欧美激情第四页| 婷婷综合视频| 成人网在线免费观看| 三级外国片在线观看视频| 欧美亚洲禁片免费| 久久久精品成人| 日本亚洲一区二区| 成人一区二区三区四区| 欧美性受ⅹ╳╳╳黑人a性爽| 欧美一卡在线观看| 久久精品www人人爽人人| 国产成人免费视频网站| 欧美日韩系列| 制服丝袜在线播放| 日韩欧亚中文在线| 亚洲一区二区偷拍| 羞羞色午夜精品一区二区三区| 国产一区香蕉久久| 2024最新电影在线免费观看| 日韩美女一区二区三区四区| 性高潮久久久久久久| 视频一区视频二区在线观看| 欧美主播一区二区三区美女 久久精品人| 黄色免费在线看| 欧美视频裸体精品| 亚洲欧洲日韩综合| 成人3d精品动漫精品一二三| 国产精品自产拍在线观| 亚洲欧洲视频在线观看| 亚洲色图制服诱惑| 波多野结衣中文字幕在线播放| 国产专区一区| 成人h视频在线| 岛国成人毛片| 欧美丝袜第三区| 日韩三级在线观看视频| 精品一区二区三区在线播放视频 | 国产视频在线观看一区| 日本在线观看www| 日韩欧美在线观看一区二区三区| 国产第一页第二页| 国产丝袜美腿一区二区三区| 又色又爽又黄视频| 欧美中文字幕一区二区| 亚洲最大的网站| 欧美人xxx| 精品国产一区二区三区久久久蜜月| 国产成人在线免费视频 | 亚洲激情成人网| 无码人妻精品一区二区| 99麻豆久久久国产精品免费优播| 男女爱爱视频网站| 日韩成人免费av| 欧美乱大交xxxxx另类电影| 亚洲一线在线观看| 国产视频一区二区在线| 一级片黄色免费| 国产欧美欧美| 久久久久se| 24小时免费看片在线观看| 一区国产精品视频| 欧美少妇bbw| 亚洲r级在线视频| 亚欧精品视频一区二区三区| 成人听书哪个软件好| 久久久久99精品成人片| 日韩理论电影大全| 国产有码一区二区| 亚洲欧洲日本韩国| 色综合久久悠悠| 国产欧美日韩综合精品一区二区三区| 国产精品视频一二三区| 日韩不卡一二三| 国产精品综合| 青青草国产免费| 中文字幕日韩一区二区不卡| 五月婷婷一区| 久久久久毛片免费观看| 欧美黑人狂野猛交老妇| 99视频在线观看地址| 亚洲全黄一级网站| 天天干天天摸天天操| 色哟哟在线观看一区二区三区| 精品一级少妇久久久久久久| 亚洲视频网在线直播| 超薄肉色丝袜一二三| 久久一留热品黄| 97超碰人人爽| 蜜乳av一区二区| 久久视频免费在线| 国语一区二区三区| 懂色av一区二区三区在线播放| 国产一区二区三区| 91美女片黄在线观看游戏| 国产精品99| 久久久久久久久久久成人| 免费黄色在线网站| www.日韩系列| 亚洲色欧美另类| 精品福利在线导航| 高潮毛片7777777毛片| 色综合色狠狠天天综合色| 日韩精品在线不卡| 精品久久久久久久久久| 国产黄色片免费看| 疯狂做受xxxx高潮欧美日本 | 国产视频欧美| 妞干网在线免费视频| 希岛爱理av一区二区三区| 亚洲一区二区三区乱码| 性xxxx欧美老肥妇牲乱| 黄色一级视频播放| 韩国在线一区| av动漫在线观看| 亚洲一区二区日韩| 粉嫩av一区二区三区天美传媒| 你懂的网址国产 欧美| 欧美激情视频一区二区三区| 先锋影音国产精品| 欧美亚洲一级二级| 日韩欧美电影| 日本a在线天堂| 精品毛片免费观看| 狠狠爱一区二区三区| 日本在线中文字幕一区| 99久久99| 香蕉久久夜色精品国产使用方法| 欧美精品人人做人人爱视频| 欧美在线免费看视频| 黄色一级视频播放| 国产欧美三级| 波多野结衣xxxx| 高清在线成人网| 久久av无码精品人妻系列试探| 国产成人av福利| 国产精品无码一区二区三区免费| 国产精品一区二区在线看| 人妻丰满熟妇av无码区app| 美女网站在线免费欧美精品| 无码国产精品久久一区免费| 久久影院午夜片一区| 亚洲熟女毛茸茸| 国产亚洲成av人在线观看导航| 精品一区二区6| 国产欧美一区二区三区鸳鸯浴| 国产麻豆视频在线观看| 香蕉成人伊视频在线观看| 高潮无码精品色欲av午夜福利| 欧美一级二级三级蜜桃| 日本大片在线观看| 欧美巨乳美女视频| 播放一区二区| 国产精品av在线播放| 在线观看爽视频| 亚洲a成v人在线观看| 无码日韩精品一区二区免费| 中文字幕第50页| 日本不卡在线视频| 永久免费未满蜜桃| 国产精品九色蝌蚪自拍| 欧美a∨亚洲欧美亚洲| 884aa四虎影成人精品一区| 中文在线字幕免费观| 欧美婷婷六月丁香综合色| 国产刺激高潮av| 久久精品最新地址| 在线国产成人影院| 国产精品免费观看在线| 国产精品视频3p| av磁力番号网| 免费高清视频精品| 国产精品三级在线观看无码| 亚洲精品老司机| 91丨porny丨在线中文| 国产亚洲激情视频在线| 欧美aa免费在线| 国产乱码一区| 一道本一区二区三区| 国产一区二区三区在线免费| 久久精品国产成人一区二区三区 | 欧洲毛片在线| 国内伊人久久久久久网站视频 | 在线女人免费视频| 国产精品久久精品国产| 综合精品一区| 永久免费黄色片| 国产精品免费视频观看| 免费在线不卡av| 在线观看视频99| 成人黄色免费观看| 亚洲国产欧美一区二区三区不卡| 六月天综合网| 手机免费av片| 国产欧美一区二区三区在线看蜜臀| 日韩在线播放中文字幕| 欧美男人的天堂一二区| 亚洲综合色av| 国产精品探花在线观看| 国产精品69页| 国产午夜精品久久久久久免费视| 亚洲成人第一网站| 亚洲日韩第一页| 日本不卡一二三| 日本一区二区在线| 日本午夜一本久久久综合| 一区二区伦理片| 欧美日韩一区二区三区不卡| 91ph在线| 99国产超薄肉色丝袜交足的后果 | 久久综合色视频| 日本vs亚洲vs韩国一区三区二区| 黄色正能量网站| 色综合色综合色综合| 二区三区在线| 欧美国产日韩精品| 99re8这里有精品热视频免费| 亚洲激情偷拍| 手机免费av片| 一区二区三区四区激情| 免费观看毛片网站| 97超级碰碰碰久久久| 免费欧美电影| 台湾成人av| 国产精品综合二区| 日本三级中文字幕| 亚洲色图15p| 青青在线精品| 97碰在线视频| 国产最新精品免费| 我和岳m愉情xxxⅹ视频| 在线精品视频一区二区| 熟妇人妻系列aⅴ无码专区友真希 熟妇人妻av无码一区二区三区 | 狠狠狠综合7777久夜色撩人| 国产精品久久久久久久久久久不卡| 日韩影片在线观看| 91国视频在线| 国产精品美女久久久久久| jizz中国女人| 日韩亚洲精品电影| 91麻豆精品国产91久久久久推荐资源| 国产精品12345| 国产乱码精品一品二品| 欧美三级韩国三级日本三斤在线观看 | 国产精品第157页| 国产亚洲成年网址在线观看| 国产丝袜在线视频| 欧美专区在线播放| 成人三级毛片| 看欧美ab黄色大片视频免费| 亚洲视频一区在线观看| 天天舔天天干天天操| 国产欧美婷婷中文| av不卡在线| 亚洲av鲁丝一区二区三区 | 777色狠狠一区二区三区| 多野结衣av一区| 在线无限看免费粉色视频|