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

字節一面:事務還沒提交的時候,Redolog 能不能被持久化到磁盤呢?

存儲 存儲軟件
每個線程都有自己 binlog cache 區域,在事務運行的過程中,MySQL 會先把日志寫到 binlog cache 中,等到事務真正提交的時候,再統一把 binlog cache 中的數據寫到 binlog 文件中。(binlog cache 有很多個,binlog 文件只有一個!)

又是被自己菜醒的一天,總結面經看到這題目聽都沒聽過,打開百度就像吃飯一樣自然

老規矩,背誦版在文末。點擊閱讀原文可以直達我收錄整理的各大廠面試真題

首先,咱需要明白的是,啥是持久化?

聽起來高大上,換句簡單的話來說,就是把數據寫到磁盤上,也成為落盤。

那為啥要做持久化到磁盤?

目的就是可以在數據丟失后進行恢復,保證數據不丟失。

那么對于 MySQL 來說,只要 binlog 和 redolog 都能正確持久化到磁盤上,就可以保證數據不丟失了。

由此引出文題,不過在講 redolog 之前,我們還是有必要先來說一下 binlog 的持久化操作。

binlog 持久化

這里引入了一個新的概念:binlog cache

從名字就能看出來,binlog cache 其實就是一片內存區域,充當緩存的作用。

每個線程都有自己 binlog cache 區域,在事務運行的過程中,MySQL 會先把日志寫到 binlog cache 中,等到事務真正提交的時候,再統一把 binlog cache 中的數據寫到 binlog 文件中。(binlog cache 有很多個,binlog 文件只有一個!)

事實上,這個從 binlog cache 寫到 binlog 文件中的操作,并不就是落盤操作了,這里僅僅是把 binlog 寫到了文件系統的 page cache 上(這一步對應下圖中的 write 操作)。

簡單解釋下文件系統的 page cache:

CPU 如果要訪問外部磁盤上的文件,需要首先將這些文件的內容拷貝到內存中,由于硬件的限制,從磁盤到內存的數據傳輸速度是很慢的,如果現在物理內存有空余,干嘛不用這些空閑內存來緩存一些磁盤的文件內容呢,這部分用作緩存磁盤文件的內存就叫做 page cache。

很多同學看到這里可能覺得特別特別熟悉,是的,和 CPU 里的高速緩存是不是很像?兩者其實都是利用的局部性原理,只不過高速緩存是 CPU 緩存內存的數據,而 page cache 是內存緩存磁盤的數據,這也體現了操作系統內存層次結構分級的思想。

所以,最后需要把 page cache 中的數據同步到磁盤上,才算真正完成了 binlog 的持久化(這一步對應下圖中的 fsync 操作)。一般情況下,我們認為 fsync 才占磁盤的 IOPS (Input/Output Operations Per Second)

write 和 fsync 的時機,是由參數 sync_binlog 控制的:

  • sync_binlog = 0,每次提交事務的時候,只進行 write,不進行 fsync
  • sync_binlog = 1候,每次提交事務的時候,執行 write 和 fsync
  • sync_binlog = N(N>1),每次提交事務的時候,執行 write,累積 N 個事務后再執行 fsync

可以看出來,如果業務場景涉及到的 IO 操作很多的話,可以適當增大 sync_binlog 的值,提高性能。但是也存在一定的風險,比如你設置成 100,萬一在第 80 個事務提交的時候數據庫宕機了,那這些事務的 binlog 日志由于沒有執行 fsync,也就丟失了。

redolog 持久化

類比 binlog,在事務執行過程中,binlog 都是存在 binlog cache 中,redolog 也有這樣一塊內存區域,叫作 redolog buffer。

在事務運行的過程中,MySQL 會先把日志寫到 redolog buffer 中,等到事務真正提交的時候,再統一把 redolog buffer 中的數據寫到 redolog 文件中。和 binlog 的落盤操作一樣,這個從 redolog buffer 寫到 redolog 文件中的操作,并不就是落盤操作了,這里僅僅是把 redolog 寫到了文件系統的 page cache 上,最后還需要執行 fsync 才能夠實現真正的落盤。

解釋下 redo log buffer?

在一個事務的更新過程中,日志是要寫多次的。比如下面這個事務:

  1. begin
  2.  insert into table1 ... 
  3.  insert into table2 ... 
  4. commit

這個事務要往兩個表 table1 和 table2 中插入記錄,為了確保這個事務不被拆開,一次性的完整寫入日志文件中,在插入數據的過程中,我們需要把生成的日志都先保存起來。redolog buffer 就是這么一個用來先存 redo 日志的地方。

也就是說,在執行第一條 insert 語句的時候,redolog buffer 也就寫入了這條記錄的日志。

不同于 binlog cache 每個線程都有一個,redolog buffer 只有那么一個。

事實上,日志寫到 redolog buffer 是很快的,wirte 到 page cache 也差不多,但是 fsync 持久化到磁盤的速度就慢多了,為了控制 redo log 的寫入策略,InnoDB 提供了 innodb_flush_log_at_trx_commit 參數,它有三種可能取值:

  • innodb_flush_log_at_trx_commit = 0,每次事務提交的時候,都只是把 redolog 留在 redolog buffer 中
  • innodb_flush_log_at_trx_commit = 1,每次事務提交的時候,都執行 fsync 將 redolog 直接持久化到磁盤
  • innodb_flush_log_at_trx_commit = 2,每次事務提交的時候,都只執行 write 將 redolog 寫到文件系統的 page cache 中
  • 說了這么多,各位小伙伴們對 binlog 和 redolog 的持久化機制想必都有所了解了,我們來看文題:事務還沒提交的時候,redolog 能不能被持久化到磁盤呢?

先說答案,答案就是有可能。

分析下 redolog 可能存在的三種狀態(binlog 也差不多):

  • 事務執行過程中,存在 MySQL 的進程內存中的 redolog buffer 中
  • 事務提交,執行 write 操作存在文件系統的 page cache 中,但是沒有執行 fsync 操作持久化到磁盤
  • 事務提交,執行 fsync 操作持久化到磁盤

至于為什么說事務還沒提交的時候,redolog 也有可能被持久化到磁盤呢?

InnoDB 有一個后臺線程,每隔 1 秒輪詢一次,具體的操作是這樣的:調用 write 將 redolog buffer 中的日志寫到文件系統的 page cache,然后調用 fsync 持久化到磁盤。而在事務執行中間過程的 redolog 都是直接寫在 redolog buffer 中的,也就是說,一個沒有提交的事務的 redolog,也是有可能會被后臺線程一起持久化到磁盤的。

另外,除了后臺線程每秒一次的輪詢操作外,還有兩種場景會讓一個沒有提交的事務的 redolog 寫盤:

  • innodb_flush_log_at_trx_commit 設置是 1,這樣并行的某個事務提交的時候,就會順帶將這個事務的 redolog buffer 持久化到磁盤

舉個例子,假設事務 A 執行到一半,已經寫了一些 redolog 到 redolog buffer 中,這時候有另外一個事務 B 提交,按照 innodb_flush_log_at_trx_commit = 1 的邏輯,事務 B 要把 redolog buffer 里的日志全部持久化到磁盤,這時候,就會帶上事務 A 在 redolog buffer 里的日志一起持久化到磁盤

  • redo log buffer 占用的空間達到 redolo buffer 大小(由參數 innodb_log_buffer_size 控制,默認是 8MB)一半的時候,后臺線程會主動寫盤。不過由于這個事務并沒有提交,所以這個寫盤動作只是 write 到了文件系統的 page cache,仍然是在內存中,并沒有調用 fsync 真正落盤

最后放上這道題的背誦版:

  • 面試官:
  • 問題:事務還沒提交的時候,redo log 能不能被持久化到磁盤呢?

相關問題:MySQL 是如何保證數據不丟失的呢?

 小牛肉:事務還沒有提交的時候,redo log 是有可能被持久化到磁盤的。

redolog 的具體落盤操作是這樣的:在事務運行的過程中,MySQL 會先把日志寫到 redolog buffer 中,等到事務真正提交的時候,再統一把 redolog buffer 中的數據寫到 redolog 文件中。不過這個從 redolog buffer 寫到 redolog 文件中的操作也就是 write 并不就是落盤操作了,這里僅僅是把 redolog 寫到了文件系統的 page cache 上,最后還需要執行 fsync 才能夠實現真正的落盤。

也就是說,redolog 其實存在三種狀態:

  • 事務執行過程中,存在 MySQL 的進程內存中的 redolog buffer 中
  • 事務提交,執行 write 操作存在文件系統的 page cache 中,但是沒有執行 fsync 操作持久化到磁盤
  • 事務提交,執行 fsync 操作持久化到磁盤

額為什么說事務還沒提交的時候,redolog 也有可能被持久化到磁盤呢?

主要有三種可能的原因:

 

  • 第一種情況:InnoDB 有一個后臺線程,每隔 1 秒輪詢一次,具體的操作是這樣的:調用 write 將 redolog buffer 中的日志寫到文件系統的 page cache,然后調用 fsync 持久化到磁盤。而在事務執行中間過程的 redolog 都是直接寫在 redolog buffer 中的,也就是說,一個沒有提交的事務的 redolog,也是有可能會被后臺線程一起持久化到磁盤的。
  • 第二種情況:innodb_flush_log_at_trx_commit 設置是 1,這個參數的意思就是,每次事務提交的時候,都執行 fsync 將 redolog 直接持久化到磁盤(還有 0 和 2 的選擇,0 表示每次事務提交的時候,都只是把 redolog 留在 redolog buffer 中;2 表示每次事務提交的時候,都只執行 write 將 redolog 寫到文件系統的 page cache 中)。舉個例子,假設事務 A 執行到一半,已經寫了一些 redolog 到 redolog buffer 中,這時候有另外一個事務 B 提交,按照 innodb_flush_log_at_trx_commit = 1 的邏輯,事務 B 要把 redolog buffer 里的日志全部持久化到磁盤,這時候,就會帶上事務 A 在 redolog buffer 里的日志一起持久化到磁盤
  • 第三種情況:redo log buffer 占用的空間達到 redolo buffer 大小(由參數 innodb_log_buffer_size 控制,默認是 8MB)一半的時候,后臺線程會主動寫盤。不過由于這個事務并沒有提交,所以這個寫盤動作只是 write 到了文件系統的 page cache,仍然是在內存中,并沒有調用 fsync 真正落盤

 

責任編輯:武曉燕 來源: 飛天小牛肉
相關推薦

2024-01-02 07:55:26

MySQLRedolog緩存

2024-11-11 10:34:55

2022-03-30 10:10:17

字節碼棧空間

2022-12-27 17:40:57

意向鎖MySQLInnoDB

2022-08-13 12:07:14

URLHTTP加密

2024-09-19 08:51:01

HTTP解密截取

2022-10-10 08:13:16

遞歸通用代碼

2024-11-26 08:52:34

SQL優化Kafka

2021-06-15 11:33:48

監控微信聊天前端

2022-05-10 22:00:41

UDPTCP協議

2022-01-05 21:54:51

網絡分層系統

2022-11-30 17:13:05

MySQLDynamic存儲

2019-11-21 09:25:23

AI 數據人工智能

2022-10-19 14:08:42

SYNTCP報文

2022-12-13 18:09:25

連接狀態客戶端

2021-05-08 11:32:42

監控信聊天

2022-08-18 17:44:25

HTTPS協議漏洞

2025-09-03 10:01:05

2022-06-01 11:52:42

網站客戶端網絡

2010-04-13 10:02:16

索引
點贊
收藏

51CTO技術棧公眾號

欧美另类极品videosbest最新版本| 中文字幕电影一区| 中文字幕亚洲精品| 制服丝袜中文字幕第一页| a视频在线播放| 成人免费视频一区| 国产成人久久精品| a级黄色片免费看| 亚洲精品小区久久久久久| 欧美色区777第一页| 日韩成人三级视频| 亚洲国产精品无码久久| 美女精品在线| 欧美精品一区二区三区国产精品 | 久久99亚洲网美利坚合众国| 91在线一区二区三区| 成人xvideos免费视频| 妺妺窝人体色www聚色窝仙踪| 国产一区二区三区视频在线| 欧美日韩精品国产| 黄频视频在线观看| 日韩福利一区二区| 国产成人福利片| 国产精品偷伦免费视频观看的 | 一区二区三区毛片| 97久久夜色精品国产九色 | 亚洲天堂2018av| 爱情岛论坛亚洲品质自拍视频网站| 成人性视频网站| 国产日韩在线播放| 欧美日韩一二三四区| 欧美在线网站| 中文字幕亚洲一区| 一级黄色免费毛片| 国产成人精选| 亚洲图片有声小说| 欧美久久久久久一卡四| 亚洲乱码国产乱码精品精软件| 日韩一级精品| 欧美黑人视频一区| 黄色a级片在线观看| 日韩啪啪电影网| 亚洲一二在线观看| 人人妻人人澡人人爽人人精品| 在线成人视屏| 欧洲另类一二三四区| 欧美成人精品欧美一级乱| 黄在线观看免费网站ktv| 久久久久高清精品| 蜜桃欧美视频| 免费毛片在线| 国产亚洲欧美一区在线观看| 久久久久久国产精品mv| 中文字幕 国产| 小小影院久久| 久久久国产一区二区三区| jizzjizzjizz国产| 97视频热人人精品免费| 色婷婷**av毛片一区| 国产在线免费av| 国产精品成人a在线观看| 中文字幕日韩av| 亚洲AV成人无码精电影在线| 偷拍欧美精品| 亚洲欧美日韩精品| 精品人妻无码中文字幕18禁| 天堂精品久久久久| 欧美刺激午夜性久久久久久久| 九九热在线免费| 黄色在线网站噜噜噜| 欧美性感美女h网站在线观看免费| 不卡中文字幕在线| 黄网av在线| 欧美日韩在线影院| 日本五级黄色片| а√在线中文在线新版| 色综合视频在线观看| 青青青在线视频免费观看| 日韩黄色三级| 精品奇米国产一区二区三区| 午夜不卡福利视频| julia中文字幕一区二区99在线| 欧美日本一道本在线视频| 国产在线视频三区| 欧美sss在线视频| 伊人精品在线观看| 三级影片在线看| 99国内精品| 国产精品免费小视频| 精品人妻一区二区色欲产成人| 国产精品a久久久久| 欧美在线观看一区二区三区| 日韩乱码一区二区三区| 国产一区二区0| 欧美极品一区二区| 国产在线激情| 日韩欧亚中文在线| 一区二区三区国产好的精华液| 日韩制服诱惑| 日韩三级在线观看| 久操视频免费看| 国产精品xvideos88| 国产99久久精品一区二区 夜夜躁日日躁 | 五月婷在线视频| 国产精品视频一二| 久草免费福利在线| 欧美成人app| 亚洲精品二三区| 69xxx免费视频| 日本道不卡免费一区| 韩国三级日本三级少妇99| 日韩成人免费观看| 精品无人码麻豆乱码1区2区 | 日韩影片在线观看| 亚洲区在线播放| xxxx 国产| 久久精品国产精品亚洲综合| 91精品视频免费看| 日av在线播放| 亚洲福利视频导航| 欧美国产日韩另类| 精品免费在线| 欧美尤物巨大精品爽| 免费在线不卡av| 波多野结衣中文字幕一区| 伊人久久大香线蕉av一区| 亚洲性色av| 亚洲福利精品在线| 黄色一级视频免费| 国产尤物一区二区| 国产伦精品一区二区三区高清版| 少妇又色又爽又黄的视频| 亚洲色图制服丝袜| 手机看片一级片| 精品国产乱码| 欧美美女18p| 国产精品久久777777换脸| 国产91精品一区二区| 做爰高潮hd色即是空| 国产精品久久久久77777丨| 国产丝袜一区二区三区| 中文字幕在线观看免费视频| 成人丝袜高跟foot| 国产一二三在线视频| 亚洲高清在线一区| 久久资源免费视频| 国产乱码久久久久| 亚洲人亚洲人成电影网站色| 中文字幕一区久久| 一区二区三区四区在线观看国产日韩| 69av在线视频| 性xxxxbbbb| 欧美性20hd另类| 91l九色lporny| 青青草成人在线观看| 一区二区视频在线免费| 国产精品国产亚洲精品| 亚洲精品一区二区网址| 在线观看日本网站| 国产蜜臀97一区二区三区 | 日本一区二区在线免费观看| 精久久久久久| 久久er99热精品一区二区三区| 调教视频免费在线观看| 欧美日韩一区二区三区视频| 亚洲精品自拍视频在线观看| 国产精品丝袜xxxxxxx| 91天堂在线视频| 久久免费电影| 国产视频亚洲精品| 亚洲中文字幕在线一区| 亚洲欧美综合在线精品| 香蕉视频免费网站| 性一交一乱一区二区洋洋av| 色姑娘综合av| 国产一区二区视频在线看| 国内精品视频在线| 国产特黄在线| 91精品国产综合久久国产大片| 影音先锋男人在线| 国产综合成人久久大片91| 屁屁影院ccyy国产第一页| 秋霞在线一区| 国产噜噜噜噜噜久久久久久久久| 国产在线91| 欧美一区二区三区成人| 日本二区三区视频| 成人自拍视频在线观看| 欧美精品第三页| 欧美精品国产一区| 欧洲精品码一区二区三区免费看| 偷拍自拍在线看| 色偷偷av一区二区三区| 在线视频你懂得| 亚洲韩国精品一区| 久久精品三级视频| 懂色av一区二区三区免费看| 草草草在线视频| 国产一区观看| 亚洲区一区二区三区| 激情小说亚洲色图| 成人精品视频99在线观看免费| 男人天堂手机在线| 亚洲精品久久久久中文字幕欢迎你| 国产无套粉嫩白浆内谢| www.成人网.com| 亚洲妇熟xx妇色黄蜜桃| 免费视频一区二区三区在线观看| 另类欧美小说| 亚洲日本va| 97成人超碰免| 在线观看电影av| 日韩综合中文字幕| 青青草在线视频免费观看| 欧美本精品男人aⅴ天堂| 亚洲天天综合网| 色婷婷综合中文久久一本| 精品少妇一二三区| 亚洲另类在线视频| 又嫩又硬又黄又爽的视频| 久久理论电影网| 日本道中文字幕| 国产iv一区二区三区| 99九九99九九九99九他书对| 久久精品官网| 欧美国产亚洲一区| 精品国产一区二区三区香蕉沈先生| 国产精品日韩一区| 92国产精品| 性色av一区二区三区免费| 久久视频www| 亚洲精品mp4| 亚洲精品字幕在线| 日韩欧美国产小视频| 国产精品伦理一区| 欧美日韩1区2区| 91精品国产乱码久久久久| 91国偷自产一区二区开放时间 | 欧美精品www| 国产精品秘入口| 亚洲精品一区二区三区不| 在线亚洲欧美日韩| 在线精品亚洲一区二区不卡| 老熟妇仑乱一区二区av| 精品久久久久久亚洲精品 | 久久久精品免费免费| 久久人人爽人人人人片| av男人天堂一区| 偷拍女澡堂一区二区三区| 狠狠色伊人亚洲综合成人| 精品视频免费在线播放| 日韩香蕉视频| 国产av无码专区亚洲精品| 在线一区欧美| 成人三级视频在线播放| 欧美午夜国产| 日韩中文字幕在线免费| 国产精品亚洲综合色区韩国| 人妻有码中文字幕| 午夜欧美精品久久久久久久| 激情五月六月婷婷| 欧美日韩网站| 国产精品成人久久电影| 国产欧美另类| 国产一区二区在线免费播放| 国产欧美日韩综合一区在线播放 | 亚洲精品美女91| 草草久久久无码国产专区| 久久性色av| 一级黄色录像在线观看| 国产裸体歌舞团一区二区| 337p日本欧洲亚洲大胆张筱雨 | 国产精品日韩在线| 999精品视频在线观看| 99视频在线播放| 亚洲国产天堂| 国产精品久久久久久久久免费 | 国产成人调教视频在线观看| 视频在线99| 欧美xxx在线观看| 黄色一级视频片| 久久99精品久久久久久国产越南| 99视频在线免费| 国产在线不卡视频| 日b视频在线观看| 国产日韩欧美一区二区三区乱码| 91久久免费视频| 亚洲黄色录像片| 亚洲天堂男人av| 日韩亚洲欧美中文三级| 99久久免费国产精精品| 欧美精品v日韩精品v韩国精品v| 凹凸精品一区二区三区| 欧美一级高清片| 韩国福利在线| 中文字幕亚洲一区在线观看 | 日韩手机在线视频| 91精品国产黑色紧身裤美女| 国产乱淫a∨片免费观看| 亚洲国产精品网站| 激情在线小视频| 欧美在线观看日本一区| 日韩欧美中文字幕一区二区三区| 91偷拍精品一区二区三区| 免费看成人哺乳视频网站| 最近中文字幕免费mv| 日韩黄色免费电影| 国产艳妇疯狂做爰视频| 国产精品精品国产色婷婷| 精品美女久久久久| 7777精品伊人久久久大香线蕉| 国产美女免费视频| 亚洲人成欧美中文字幕| 黄色成人在线网| 91黄色8090| 综合激情五月婷婷| 一区二区三区四区欧美日韩| 性色av一区二区怡红| 69xxx免费视频| 亚洲蜜桃精久久久久久久| 亚洲第一区av| 国产一区二区三区免费视频| 日韩大片在线永久免费观看网站| 久久综合久久八八| 精品裸体bbb| 日本一区网站| 免费日韩一区二区| 捆绑凌虐一区二区三区| 国产日韩精品视频一区| 亚洲精品午夜国产va久久成人| 在线视频一区二区免费| a天堂在线观看视频| 色悠悠国产精品| 99久久伊人| 亚洲女人毛片| 麻豆精品一区二区综合av| 亚洲a v网站| 一区二区三区欧美在线观看| 国产精品久久久免费视频| 精品国产乱码久久久久久影片| 欧美扣逼视频| 欧美亚洲在线观看| 亚欧日韩另类中文欧美| 精品欧美一区免费观看α√| 91原创在线视频| 久久国产精品国语对白| 福利微拍一区二区| 四虎精品成人免费网站| 欧美日本啪啪无遮挡网站| 日韩精品一区国产| 亚洲欧洲三级| 韩国精品久久久| 黄色片子在线观看| 日韩亚洲欧美成人一区| 日本片在线观看| 国产免费一区二区| 国产欧美午夜| 91porn在线| 午夜在线电影亚洲一区| 亚洲 精品 综合 精品 自拍| 青青草原成人在线视频| 精品久久综合| 污免费在线观看| 精品久久久久久中文字幕| 国产av无码专区亚洲av麻豆| 欧美激情欧美狂野欧美精品| 国产精品网址| 北条麻妃av高潮尖叫在线观看| 暴力调教一区二区三区| 狠狠人妻久久久久久综合| 日韩在线视频观看| 亚洲五码在线| 成年网站在线免费观看| 国产精品视频线看| 成人av一区二区三区在线观看| 中文字幕国产亚洲2019| 3d欧美精品动漫xxxx无尽| 影音先锋亚洲视频| 国产不卡在线视频| 中文字幕一区在线播放| 精品国产欧美成人夜夜嗨| a成人v在线| 国产真实老熟女无套内射| 久久这里只有精品视频网| 91精品国产色综合久久不8| 欧美高清自拍一区| youjizz欧美| 天天天干夜夜夜操| 一区二区日韩电影| 国产尤物视频在线| av蓝导航精品导航| 日韩精品乱码免费| 国产一级久久久久毛片精品| 日韩欧美国产系列| 天堂久久午夜av| 黄色成人在线看| 亚洲人一二三区| 成人免费在线视频网| 国产亚洲情侣一区二区无 | 日韩精品在线视频免费观看|