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

必須了解的MySQL三大日志:binlog、redo log和undo log

數(shù)據(jù)庫 MySQL
作為開發(fā),我們重點需要關(guān)注的是二進(jìn)制日志(binlog)和事務(wù)日志(包括redo log和undo log),本文接下來會詳細(xì)介紹這三種日志。

 日志是mysql數(shù)據(jù)庫的重要組成部分,記錄著數(shù)據(jù)庫運行期間各種狀態(tài)信息。mysql日志主要包括錯誤日志、查詢?nèi)罩尽⒙樵內(nèi)罩尽⑹聞?wù)日志、二進(jìn)制日志幾大類。作為開發(fā),我們重點需要關(guān)注的是二進(jìn)制日志(binlog)和事務(wù)日志(包括redo log和undo log),本文接下來會詳細(xì)介紹這三種日志。

binlog

binlog用于記錄數(shù)據(jù)庫執(zhí)行的寫入性操作(不包括查詢)信息,以二進(jìn)制的形式保存在磁盤中。binlog是mysql的邏輯日志,并且由Server層進(jìn)行記錄,使用任何存儲引擎的mysql數(shù)據(jù)庫都會記錄binlog日志。

  • 邏輯日志:可以簡單理解為記錄的就是sql語句。
  •  物理日志:因為mysql數(shù)據(jù)最終是保存在數(shù)據(jù)頁中的,物理日志記錄的就是數(shù)據(jù)頁變更。

binlog是通過追加的方式進(jìn)行寫入的,可以通過max_binlog_size參數(shù)設(shè)置每個binlog文件的大小,當(dāng)文件大小達(dá)到給定值之后,會生成新的文件來保存日志。

binlog使用場景

在實際應(yīng)用中,binlog的主要使用場景有兩個,分別是主從復(fù)制和數(shù)據(jù)恢復(fù)。

  •  主從復(fù)制:在Master端開啟binlog,然后將binlog發(fā)送到各個Slave端,Slave端重放binlog從而達(dá)到主從數(shù)據(jù)一致。
  •  數(shù)據(jù)恢復(fù):通過使用mysqlbinlog工具來恢復(fù)數(shù)據(jù)。

binlog刷盤時機(jī)

對于InnoDB存儲引擎而言,只有在事務(wù)提交時才會記錄biglog,此時記錄還在內(nèi)存中,那么biglog是什么時候刷到磁盤中的呢?mysql通過sync_binlog參數(shù)控制biglog的刷盤時機(jī),取值范圍是0-N:

  •  0:不去強(qiáng)制要求,由系統(tǒng)自行判斷何時寫入磁盤;
  •  1:每次commit的時候都要將binlog寫入磁盤;
  •  N:每N個事務(wù),才會將binlog寫入磁盤。

從上面可以看出,sync_binlog最安全的是設(shè)置是1,這也是MySQL 5.7.7之后版本的默認(rèn)值。但是設(shè)置一個大一些的值可以提升數(shù)據(jù)庫性能,因此實際情況下也可以將值適當(dāng)調(diào)大,犧牲一定的一致性來獲取更好的性能。

推薦閱讀:Java面試題拆解

binlog日志格式

binlog日志有三種格式,分別為STATMENT、ROW和MIXED。

在 MySQL 5.7.7之前,默認(rèn)的格式是STATEMENT,MySQL 5.7.7之后,默認(rèn)值是ROW。日志格式通過binlog-format指定。

STATMENT

基于SQL語句的復(fù)制(statement-based replication, SBR),每一條會修改數(shù)據(jù)的sql語句會記錄到binlog中。

  •  優(yōu)點:不需要記錄每一行的變化,減少了binlog日志量,節(jié)約了IO, 從而提高了性能;
  •  缺點:在某些情況下會導(dǎo)致主從數(shù)據(jù)不一致,比如執(zhí)行sysdate()、slepp()等。

ROW

基于行的復(fù)制(row-based replication, RBR),不記錄每條sql語句的上下文信息,僅需記錄哪條數(shù)據(jù)被修改了。

  •  優(yōu)點:不會出現(xiàn)某些特定情況下的存儲過程、或function、或trigger的調(diào)用和觸發(fā)無法被正確復(fù)制的問題;
  •  缺點:會產(chǎn)生大量的日志,尤其是alter table的時候會讓日志暴漲

MIXED

基于STATMENT和ROW兩種模式的混合復(fù)制(mixed-based replication, MBR),一般的復(fù)制使用STATEMENT模式保存binlog,對于STATEMENT模式無法復(fù)制的操作使用ROW模式保存binlog

redo log

為什么需要redo log

我們都知道,事務(wù)的四大特性里面有一個是持久性,具體來說就是只要事務(wù)提交成功,那么對數(shù)據(jù)庫做的修改就被永久保存下來了,不可能因為任何原因再回到原來的狀態(tài)。那么mysql是如何保證一致性的呢?最簡單的做法是在每次事務(wù)提交的時候,將該事務(wù)涉及修改的數(shù)據(jù)頁全部刷新到磁盤中。但是這么做會有嚴(yán)重的性能問題,主要體現(xiàn)在兩個方面:

  •  因為Innodb是以頁為單位進(jìn)行磁盤交互的,而一個事務(wù)很可能只修改一個數(shù)據(jù)頁里面的幾個字節(jié),這個時候?qū)⑼暾臄?shù)據(jù)頁刷到磁盤的話,太浪費資源了!
  •  一個事務(wù)可能涉及修改多個數(shù)據(jù)頁,并且這些數(shù)據(jù)頁在物理上并不連續(xù),使用隨機(jī)IO寫入性能太差!

因此mysql設(shè)計了redo log,具體來說就是只記錄事務(wù)對數(shù)據(jù)頁做了哪些修改,這樣就能完美地解決性能問題了(相對而言文件更小并且是順序IO)。

搜索Java知音公眾號,回復(fù)“后端面試”,送你一份Java面試題寶典

redo log基本概念

redo log包括兩部分:一個是內(nèi)存中的日志緩沖(redo log buffer),另一個是磁盤上的日志文件(redo log file)。mysql每執(zhí)行一條DML語句,先將記錄寫入redo log buffer,后續(xù)某個時間點再一次性將多個操作記錄寫到redo log file。這種先寫日志,再寫磁盤的技術(shù)就是MySQL里經(jīng)常說到的WAL(Write-Ahead Logging) 技術(shù)。

在計算機(jī)操作系統(tǒng)中,用戶空間(user space)下的緩沖區(qū)數(shù)據(jù)一般情況下是無法直接寫入磁盤的,中間必須經(jīng)過操作系統(tǒng)內(nèi)核空間(kernel space)緩沖區(qū)(OS Buffer)。因此,redo log buffer寫入redo log file實際上是先寫入OS Buffer,然后再通過系統(tǒng)調(diào)用fsync()將其刷到redo log file中,過程如下:

mysql支持三種將redo log buffer寫入redo log file的時機(jī),可以通過innodb_flush_log_at_trx_commit參數(shù)配置,各參數(shù)值含義如下:

redo log記錄形式

前面說過,redo log實際上記錄數(shù)據(jù)頁的變更,而這種變更記錄是沒必要全部保存,因此redo log實現(xiàn)上采用了大小固定,循環(huán)寫入的方式,當(dāng)寫到結(jié)尾時,會回到開頭循環(huán)寫日志。如下圖:

同時我們很容易得知,在innodb中,既有redo log需要刷盤,還有數(shù)據(jù)頁也需要刷盤,redo log存在的意義主要就是降低對數(shù)據(jù)頁刷盤的要求。在上圖中,write pos表示redo log當(dāng)前記錄的LSN(邏輯序列號)位置,check point表示數(shù)據(jù)頁更改記錄刷盤后對應(yīng)redo log所處的LSN(邏輯序列號)位置。

write pos到check point之間的部分是redo log空著的部分,用于記錄新的記錄;check point到write pos之間是redo log待落盤的數(shù)據(jù)頁更改記錄。當(dāng)write pos追上check point時,會先推動check point向前移動,空出位置再記錄新的日志。

啟動innodb的時候,不管上次是正常關(guān)閉還是異常關(guān)閉,總是會進(jìn)行恢復(fù)操作。因為redo log記錄的是數(shù)據(jù)頁的物理變化,因此恢復(fù)的時候速度比邏輯日志(如binlog)要快很多。

重啟innodb時,首先會檢查磁盤中數(shù)據(jù)頁的LSN,如果數(shù)據(jù)頁的LSN小于日志中的LSN,則會從checkpoint開始恢復(fù)。

還有一種情況,在宕機(jī)前正處于checkpoint的刷盤過程,且數(shù)據(jù)頁的刷盤進(jìn)度超過了日志頁的刷盤進(jìn)度,此時會出現(xiàn)數(shù)據(jù)頁中記錄的LSN大于日志中的LSN,這時超出日志進(jìn)度的部分將不會重做,因為這本身就表示已經(jīng)做過的事情,無需再重做。

redo log與binlog區(qū)別

由binlog和redo log的區(qū)別可知:binlog日志只用于歸檔,只依靠binlog是沒有crash-safe能力的。但只有redo log也不行,因為redo log是InnoDB特有的,且日志上的記錄落盤后會被覆蓋掉。因此需要binlog和redo log二者同時記錄,才能保證當(dāng)數(shù)據(jù)庫發(fā)生宕機(jī)重啟時,數(shù)據(jù)不會丟失。

undo log

數(shù)據(jù)庫事務(wù)四大特性中有一個是原子性,具體來說就是 原子性是指對數(shù)據(jù)庫的一系列操作,要么全部成功,要么全部失敗,不可能出現(xiàn)部分成功的情況。

實際上,原子性底層就是通過undo log實現(xiàn)的。undo log主要記錄了數(shù)據(jù)的邏輯變化,比如一條INSERT語句,對應(yīng)一條DELETE的undo log,對于每個UPDATE語句,對應(yīng)一條相反的UPDATE的undo log,這樣在發(fā)生錯誤時,就能回滾到事務(wù)之前的數(shù)據(jù)狀態(tài)。推薦閱讀:Java面試題拆解

同時,undo log也是MVCC(多版本并發(fā)控制)實現(xiàn)的關(guān)鍵,這部分內(nèi)容在面試中的老大難-mysql事務(wù)和鎖,一次性講清楚!中有介紹,不再贅述。 

 

責(zé)任編輯:龐桂玉 來源: Java知音
相關(guān)推薦

2025-06-06 07:02:43

2024-05-30 08:03:17

2023-11-23 13:17:39

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

2024-05-28 00:10:00

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

2025-01-15 13:19:09

MySQL日志事務(wù)

2021-01-26 13:47:08

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

2024-06-11 00:00:02

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

2024-12-16 00:00:05

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

2024-03-14 14:18:58

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

2021-08-03 17:20:00

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

2025-10-09 02:22:00

MySQLMVCC庫存數(shù)量

2025-01-20 08:20:00

redo logMySQL數(shù)據(jù)庫

2025-08-11 09:08:41

2022-10-12 08:01:08

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

2020-11-11 07:32:18

MySQL InnoDB 存儲

2021-02-09 10:07:23

面試MySQL存儲

2021-07-28 08:32:03

MySQLRedo存儲

2025-08-29 07:58:42

2020-09-18 11:00:28

MySQLbinlogrelay-log

2011-08-30 10:30:50

OracleUNDO LOG日志回
點贊
收藏

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

国产交换配乱淫视频免费| 国产精品一区在线免费观看| www.国产一区二区| 欧美中文一区二区| 51精品视频一区二区三区| 日韩视频一二三| 无码国精品一区二区免费蜜桃| 狂野欧美性猛交xxxx巴西| 久久精品国产欧美激情| 日韩黄色一区二区| 91精品国产66| 精品久久久久久国产91| 自拍偷拍一区二区三区| 午夜性色福利影院| 国产精品综合二区| 国产精品成人va在线观看| 日韩高清dvd碟片| 九色精品国产蝌蚪| 精品1区2区在线观看| 久久综合伊人77777麻豆最新章节| 大片免费在线观看| 亚洲国产精品av| 国产伦精品一区二区三区免| 亚洲一区二区激情| 久久久久久9| 欧美黑人一区二区三区| 精品一区二区在线观看视频| 羞羞色国产精品网站| 91精品国模一区二区三区| 激情综合网婷婷| 国产夫妻在线播放| 中文字幕一区二区在线播放| 欧美日韩天天操| 日韩在线视频免费| 国产成人精品三级| 成人做爰www免费看视频网站| 无码人妻丰满熟妇区五十路| 99在线热播精品免费99热| 欧美精品在线极品| 一级免费黄色录像| 久久久综合色| 中文字幕精品av| 丰满少妇一区二区三区| 国产精品乱战久久久| 日韩久久久久久| 手机看片国产精品| 欧美午夜在线播放| 欧美一区二区在线免费观看| 欧美丝袜在线观看| 欧美性aaa| 在线不卡中文字幕| 99日在线视频| 国产不卡精品在线| 欧美一区二区三区四区五区| 黄色aaaaaa| 国产日韩一区二区三免费高清| 欧美精品一二三四| 91插插插影院| 久久久久久久久成人| 欧美tk丨vk视频| 欧美丰满熟妇bbb久久久| 国产精品115| 日韩精品中文字幕视频在线| 欧美成人午夜精品免费| 精品国产精品| www.日韩.com| 国产suv一区二区三区| 欧美喷水视频| 777精品视频| 成人一级免费视频| 久久福利视频一区二区| 亚洲一区亚洲二区| 六月丁香综合网| 91社区在线播放| 亚洲精品视频一二三| 日本高清在线观看wwwww色| 亚洲美女视频一区| www插插插无码视频网站| 欧美三级网址| 欧美精品v国产精品v日韩精品| 中文字幕久久久久久久| 日韩三区视频| 最近2019中文字幕大全第二页 | 国内成人精品一区| 好吊妞视频一区二区三区| 日韩一区精品视频| 91在线播放国产| 少妇av一区二区| 国产精品午夜免费| 嫩草影院中文字幕| 桃花岛成人影院| 日韩色在线观看| 久久国产精品无码一级毛片| 9999国产精品| 97视频在线观看成人| 中文字幕在线观看高清| 国产成人av福利| 神马影院一区二区三区| 粗大黑人巨茎大战欧美成人| 日韩欧美成人区| 欧美一级小视频| 亚洲人成网亚洲欧洲无码| 久久精品最新地址| 亚洲熟妇无码乱子av电影| 久久99热狠狠色一区二区| 国产主播一区二区三区四区| 伊人在线视频| 一本一本大道香蕉久在线精品 | 精品网站aaa| www.日韩视频| 无码人妻熟妇av又粗又大| 国产a级毛片一区| 亚洲视频欧美在线| 日韩伦理在线一区| 欧美草草影院在线视频| 男女全黄做爰文章| 日韩精品视频网| 国产一级精品aaaaa看| 高清全集视频免费在线| 色94色欧美sute亚洲线路一久| 风韵丰满熟妇啪啪区老熟熟女| 欧美色就是色| 秋霞午夜一区二区| 无码精品人妻一区二区三区影院| 亚洲欧美日韩久久| 欧美婷婷精品激情| 亚洲国产精品嫩草影院久久av| 久久6免费高清热精品| 在线免费观看日韩视频| 国产亚洲精品bt天堂精选| 日韩国产欧美亚洲| 亚洲精品午夜| 久久夜色精品国产欧美乱| 中文字幕欧美在线观看| 国产日本欧美一区二区| 波多野结衣家庭教师视频| 老司机精品在线| 国模吧一区二区| 亚洲欧美另类一区| 亚洲影视在线观看| 一区二区三区四区影院| 欧美三级小说| 成人区精品一区二区| av网站网址在线观看| 欧美一区二区免费观在线| 日韩福利小视频| 久久99热99| 一道精品一区二区三区| 日韩久久一区| 色综合伊人色综合网站| 91精东传媒理伦片在线观看| 国产精品白丝在线| 日日夜夜精品视频免费观看| 亚洲电影在线一区二区三区| 亚洲综合中文字幕在线观看| 伊人影院在线视频| 欧美成人精精品一区二区频| 国产一级片播放| 91在线视频播放地址| 99精品视频在线看| 国产一区二区三区探花| 国产精品亚洲精品| av免费在线观看网址| 精品av综合导航| 黄色片中文字幕| 欧美国产日韩在线观看| 国产农村妇女精品久久| 欧美日韩爆操| 精品国产一区二区三区四区精华| 僵尸再翻生在线观看| 一二美女精品欧洲| 国产乱淫a∨片免费观看| 一区二区在线观看不卡| 国产又粗又长又爽| 蜜臀va亚洲va欧美va天堂| 国产人妻互换一区二区| av不卡一区二区| 日本欧美中文字幕| 亚洲成人三级| 精品国产青草久久久久福利| 精品久久久久久久久久久久久久久久 | 欧美日韩国产麻豆| 欧洲性xxxx| 国产成人av一区| 国产三级三级三级看三级| 你懂的网址国产 欧美| 精品国产乱码久久久久软件| 日韩一级二级| 欧美黑人巨大精品一区二区| 国产日产精品久久久久久婷婷| 7777精品伊人久久久大香线蕉的| 久久久久久久久久91| 欧美国产日本视频| 影音先锋资源av| 免费在线欧美视频| 国产一二三在线视频| 日韩一区欧美| 精品亚洲欧美日韩| 国产999精品在线观看| 欧美在线视频免费播放| huan性巨大欧美| 亚洲视频欧美视频| 欧美视频一二区| 欧美日韩1234| 无码人妻丰满熟妇精品| 亚洲大片在线观看| 精品国产视频在线观看| 久久久高清一区二区三区| 亚洲美女高潮久久久| 久久 天天综合| 欧美国产激情视频| 极品日韩av| 一区二区在线观| 国产99精品一区| 国产欧美一区二区在线播放| 日韩黄色在线| 国产精品主播视频| 中国字幕a在线看韩国电影| 欧美激情小视频| 色欧美激情视频在线| 亚洲欧美日韩视频一区| 人妻少妇精品无码专区久久| 在线不卡中文字幕播放| 中文区中文字幕免费看| 福利视频一区二区| 日本熟妇色xxxxx日本免费看| 亚洲人成7777| 国产老头老太做爰视频| 国产精品久久久久久久浪潮网站| 美女脱光内衣内裤| 久久免费美女视频| 国产精品无码永久免费不卡| 99久久婷婷国产综合精品电影| 性一交一黄一片| 国产麻豆一精品一av一免费| www.色就是色.com| 精品制服美女久久| 午夜精品中文字幕| 久久99国内精品| 8x8x成人免费视频| 国产精品中文欧美| 美女被艹视频网站| 国产精品12区| 图片区偷拍区小说区| 国产a级毛片一区| 四虎精品一区二区| 99久久精品国产一区| 国产又粗又长又爽| 久久久久久久综合日本| 人妻aⅴ无码一区二区三区| 欧美国产欧美综合| 四虎永久免费地址| 亚洲免费观看视频| 精品视频久久久久| 欧美日韩在线免费观看| 日韩一级在线视频| 欧美日韩一区不卡| 精品人妻一区二区三区三区四区| 日韩一二三区视频| 黄色片一区二区三区| 亚洲黄色有码视频| 黄色美女网站在线观看| 色伦专区97中文字幕| а√中文在线8| 久久99精品国产99久久6尤物| 免费在线看污片| 欧美一级电影在线| 先锋影音一区二区| 99精品99久久久久久宅男| 日韩mv欧美mv国产网站| 日韩影院一区| 综合天堂久久久久久久| 青青青青草视频| 日本中文字幕一区二区视频 | 高清日韩中文字幕| 欧美日韩国产一二| 亚洲激情中文在线| 丰满少妇久久久| 日本视频在线一区| 99免费观看视频| 日本一区二区三区四区在线视频 | 欧美在线二区| 91九色在线观看视频| 久久国产精品免费| xxxwww国产| 中文字幕亚洲一区二区va在线| 久久久久久久国产视频| 色欧美日韩亚洲| 精品国精品国产自在久不卡| 亚洲欧美日韩国产精品| av理论在线观看| 日本最新高清不卡中文字幕| 精品国产一级| 日韩精品极品视频在线观看免费| 女生裸体视频一区二区三区| 黄色a级片免费| 国产精品888| 四虎国产成人精品免费一女五男| 亚洲精品国产高清久久伦理二区| 天天干天天色综合| 欧美α欧美αv大片| 中文字幕日本在线观看| 57pao成人永久免费视频| 国产成人免费av一区二区午夜| 欧美一区二区福利| 国产精品多人| 天堂av2020| 中文字幕精品三区| 日韩色图在线观看| 精品日产卡一卡二卡麻豆| av在线播放网站| 欧美亚洲视频在线看网址| 精品国产乱码久久久久久樱花| 欧美一区二区综合| 99精品免费网| 国偷自产av一区二区三区麻豆| 中文字幕乱码亚洲精品一区| 国产精品久久久久久久久久久久久久久久久 | 国产精品高潮粉嫩av| 美日韩黄色大片| 中文精品无码中文字幕无码专区| 六月婷婷色综合| 阿v天堂2014| 色噜噜狠狠一区二区三区果冻| 日本韩国在线观看| 欧美高清性猛交| 欧美高清一级片| 黄频视频在线观看| 美女www一区二区| 成人黄色a级片| 在线免费观看一区| 女人偷人在线视频| 欧美一级淫片aaaaaaa视频| 国产成人精品福利| 人人妻人人澡人人爽欧美一区双| 国产精品亚洲综合一区在线观看| 欧美a级片免费看| 在线不卡a资源高清| 91se在线| 91丝袜美腿美女视频网站| 五月精品视频| 一区二区三区人妻| 悠悠色在线精品| 亚洲国产精品18久久久久久| 欧美激情中文字幕乱码免费| 亚洲视频一起| 精品无码国产一区二区三区av| 成人国产电影网| 国产精品老女人| 国产亚洲精品久久久久久| 国产一区二区三区朝在线观看| 亚洲精品高清视频| 国产在线乱码一区二区三区| 18岁成人毛片| 亚洲国产精品va在线看黑人动漫| 成人影院在线视频| 欧美午夜精品久久久久免费视| 日本伊人午夜精品| 中文字幕乱码av| 欧美精品一区二区三区高清aⅴ | 欧美色爱综合网| 精品黄色免费中文电影在线播放 | 精品中文字幕一区二区三区av| 黄色一级大片在线观看| 国产精品亲子乱子伦xxxx裸| 国产免费一区二区三区最新不卡| 欧美另类在线观看| 欧美顶级毛片在线播放| 日本xxxxxxx免费视频| 亚洲欧美综合另类在线卡通| 高潮毛片7777777毛片| 2025国产精品视频| 精品视频久久| 亚洲 自拍 另类 欧美 丝袜| 亚洲大片精品永久免费| 爱久久·www| 91免费人成网站在线观看18| 99成人精品| 天堂在线中文视频| 日韩精品中文字幕一区| 涩涩视频在线免费看| 日韩三级在线播放| 国产乱子伦一区二区三区国色天香| 国产黄色片视频| 在线播放精品一区二区三区| 在线日韩成人| 国产xxxxx视频| 亚洲最新在线观看| 蜜桃视频在线观看网站| 亚洲综合色激情五月| 久久精品伊人| 在线观看亚洲网站| 亚洲色无码播放| av自拍一区| 一起操在线视频| 日韩欧美黄色动漫| 羞羞的视频在线观看| 午夜精品亚洲一区二区三区嫩草 | 看片一区二区| 鲁一鲁一鲁一鲁一色|