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

色窝窝无码一区二区三区成人网站| 91国模少妇一区二区三区| 欧美jizz18性欧美| 国产一区二区美女诱惑| 久久久久久综合网天天| 在线免费看黄色片| 成人美女大片| 国产精品污www在线观看| 国产日韩欧美日韩| 一级黄色录像视频| 日韩mv欧美mv国产网站| 欧美图片一区二区三区| 好色先生视频污| 五月天婷婷视频| 日本三级亚洲精品| 欧美成人全部免费| 精品黑人一区二区三区观看时间| 伊人久久高清| 亚洲精品免费在线| 久久亚洲一区二区| 97精品人妻一区二区三区在线| 这里只有精品在线| 欧美丰满嫩嫩电影| 欧美深夜福利视频| 欧美一区二区三区| 99久久综合国产精品| 国产精品视频在线播放| 亚洲精品在线观看av| 精品国产aⅴ| 3d动漫精品啪啪一区二区竹菊| 福利视频免费在线观看| 99re在线视频| 91视频www| 91成人免费在线观看| 国产免费一级视频| 日韩亚洲在线| 美女黄色丝袜一区| 九九九视频在线观看| 福利欧美精品在线| 欧美一级xxx| 国产情侣av自拍| 国产丝袜在线观看视频| 国产精品美女久久久久久久久| 高清不卡一区二区三区| 一区二区三区免费观看视频| 免费中文字幕日韩欧美| 欧美精品成人在线| 欧美成人黄色网| 色婷婷一区二区三区| 亚洲精选在线观看| 欧美在线一级片| 一区二区亚洲视频| 日韩一级成人av| 国产精品天天av精麻传媒| 9765激情中文在线| 一区二区三区不卡视频在线观看| 亚洲女人毛片| 国产精品一二三区视频| 91视频91自| 国产日韩三区| 亚洲一区在线观| 中文精品在线| 久久久久久久久网站| 国产三级国产精品国产国在线观看 | 不用播放器的免费av| 亚洲精品一区三区三区在线观看| 欧美日韩国产在线| 性欧美大战久久久久久久| 欧美大胆的人体xxxx| 一区二区欧美精品| 嫩草影院中文字幕| 香蕉久久aⅴ一区二区三区| 亚洲欧美国产77777| 中文字幕在线中文字幕日亚韩一区| 成人影院免费观看| 国产精品蜜臀在线观看| 午夜一区二区三区| 日本不卡视频| 中文字幕亚洲区| 在线观看一区二区三区三州| 久草资源在线| 一区二区三区四区不卡视频| 国产尤物av一区二区三区| 97超碰资源站在线观看| 亚洲一区中文日韩| 你真棒插曲来救救我在线观看| 美女网站视频在线| 亚洲成人自拍网| 男人天堂1024| 亚洲高清黄色| 欧美精品xxxxbbbb| 人妻少妇偷人精品久久久任期| 日韩精品视频一区二区三区| 亚洲第一区在线观看| 免费在线观看成年人视频| 视频一区欧美| 日韩一区二区在线视频| 久草免费在线观看视频| 精品福利av| 国产91色在线|免| 中文字幕黄色av| 国产精品一区二区你懂的| 丁香婷婷久久久综合精品国产 | 少妇人妻丰满做爰xxx| 欧美日韩免费观看一区=区三区| 久久久免费在线观看| aaaaaa毛片| 国产美女视频一区| 国产乱码精品一区二区三区日韩精品| 神马精品久久| 亚洲欧美日韩系列| 北条麻妃在线视频观看| 福利一区二区| 亚洲第一福利视频| 欧美激情 一区| 在线不卡视频| 国产在线播放91| 日韩永久免费视频| 国产精品国产馆在线真实露脸| 黄色一级片黄色| 精品裸体bbb| 欧美成人一区二区三区片免费| 亚洲第一页av| 国产精品theporn| 国产精品久久久久久av下载红粉| 国产成人三级在线观看视频| 欧美国产亚洲另类动漫| 久草视频这里只有精品| 韩国成人动漫| 亚洲国产高清高潮精品美女| 在线免费看视频| 亚洲综合精品四区| 国产一区私人高清影院| 五月婷婷丁香六月| 亚洲欧美激情小说另类| 欧美午夜aaaaaa免费视频| 丁香五月缴情综合网| 久久这里只有精品视频首页| 国产亚洲欧美日韩高清| 99综合电影在线视频| 天天干天天色天天爽| 日韩精品专区| 亚洲精品999| 青青草国产在线观看| 日本伊人午夜精品| 裸模一区二区三区免费| xxxx成人| 欧美成人r级一区二区三区| 欧美巨胸大乳hitomi| 久久久久久一区二区| 狠狠色噜噜狠狠色综合久| h片在线播放| 欧美日本不卡视频| 伊人影院综合网| 久久在线精品| 欧美三级华人主播| 91www在线| 91精品国产日韩91久久久久久| 亚洲不卡的av| 久久99最新地址| 中文网丁香综合网| 在线播放成人| 久久综合电影一区| 精品人妻aV中文字幕乱码色欲| 亚洲人成精品久久久久| 亚洲欧美天堂在线| 91精品国产91久久综合| 亚洲一区国产精品| 色呦呦在线视频| 亚洲爱爱爱爱爱| 99久在线精品99re8热| 久久伊人蜜桃av一区二区| 大j8黑人w巨大888a片| 国产欧美啪啪| 91大神福利视频在线| 丝袜视频国产在线播放| 日韩欧美视频一区二区三区| 亚洲av成人无码久久精品| 日韩国产在线一| 亚洲免费在线精品一区| 久久九九精品视频| 久久人人爽人人爽人人片av高清| 国产chinasex对白videos麻豆| 亚洲免费三区一区二区| 黄色三级视频在线播放| 亚洲无中文字幕| 成人自拍爱视频| 女同一区二区免费aⅴ| 亚洲电影在线看| 99re这里只有精品在线| 国产精品少妇自拍| 免费看的av网站| 99精品免费网| 偷拍视频一区二区| 欧美欧美在线| 欧美一区第一页| 高清毛片在线看| 欧美成人免费网站| 青青草免费观看视频| 国产精品久久久久影视| 成人啪啪18免费游戏链接| 亚洲免费综合| 懂色av一区二区三区四区五区| 极品束缚调教一区二区网站| 亚洲91精品在线| 9191在线观看| 亚洲白虎美女被爆操| 精品一区二三区| 一区二区在线看| 性欧美精品中出| 国内精品在线播放| 中国丰满人妻videoshd | 国产亚洲欧美久久久久| 国产午夜亚洲精品理论片色戒| 久草福利在线观看| 久久午夜精品| 特级西西444| 精品日本12videosex| 高清日韩一区| 欧洲精品久久久久毛片完整版| 久久久欧美一区二区| jizz视频在线观看| 精品国产区一区| 国产精品色综合| 色婷婷av一区二区三区之一色屋| 我要看黄色一级片| 国产欧美日产一区| 欧美一级片黄色| 国产一区二区在线观看视频| 免费av网址在线| 欧美午夜影院| 欧美性受xxxx黑人猛交88| 精品国产一区二区三区av片| 国产精品一码二码三码在线| 欧美国产视频| 国产精品高清免费在线观看| 国产高清自产拍av在线| 久热在线中文字幕色999舞| 黄色大片在线看| 亚洲国产精品yw在线观看| a天堂在线视频| 欧美久久高跟鞋激| 国产亚洲欧美日韩高清| 黑人精品xxx一区一二区| 久久免费精彩视频| 亚洲精品日日夜夜| 好吊日在线视频| 中文字幕欧美日本乱码一线二线| 中文字幕在线永久| 成熟亚洲日本毛茸茸凸凹| 成人综合久久网| 免费在线一区观看| 丰满少妇在线观看| 日韩国产一区二| 欧美激情国产精品日韩| 国产欧美日本| 无码人妻丰满熟妇区96| 亚洲午夜极品| 日韩精品视频在线观看视频| 国产精品a级| 国产毛片久久久久久国产毛片| 欧美在线免费一级片| 久久久久亚洲av无码专区喷水| 日韩理论电影| 色中文字幕在线观看| 亚洲一区二区三区| 国产精品波多野结衣| 欧美国产小视频| 伊人久久大香线蕉综合75| 婷婷激情图片久久| 99re99热| 欧美成人高清| 久久国产午夜精品理论片最新版本| 欧美人成网站| 欧美乱大交xxxxx潮喷l头像| 亚洲国产片色| 黄色动漫网站入口| 三级不卡在线观看| 黄色永久免费网站| 国产一区二区三区蝌蚪| 国产伦理在线观看| 成人免费毛片高清视频| www.88av| 亚洲国产精品国自产拍av| 欧美a级片免费看| 亚洲精品免费播放| 日韩精品在线免费看| 日本黄色一区二区| 国产又黄又粗又猛又爽| 日韩欧美在线综合网| 全国男人的天堂网| 亚洲天堂视频在线观看| 国产在线观看免费麻豆| 久久久久国产精品免费网站| 国产黄大片在线观看| 国产精品成人播放| 久久丁香四色| 久久手机视频| 欧美激情偷拍自拍| 久久精品国产sm调教网站演员| 美女国产一区| 久久综合在线观看| 97久久人人超碰| 无码人妻精品中文字幕| 激情懂色av一区av二区av| 无码一区二区三区| 欧美日韩国产成人在线91| 亚洲乱码在线观看| 亚洲欧美激情精品一区二区| 3d成人动漫在线| 九九久久久久99精品| 僵尸再翻生在线观看| 国产精品久久久久久久电影 | 污视频网站免费观看| 一区二区三区视频观看| 欧美xxxxhdvideosex| 国产精品免费久久久| 盗摄牛牛av影视一区二区| 亚洲一区不卡在线| 亚洲免费高清| 亚洲av无日韩毛片久久| 久久老女人爱爱| 九九视频在线免费观看| 欧美午夜精品一区二区蜜桃| 亚洲狼人综合网| 久久精品亚洲一区| 日本综合视频| 久99久在线| 欧美黄免费看| 午夜久久福利视频| 国产亚洲精品精华液| 日本少妇激情舌吻| 欧美成人欧美edvon| 麻豆视频网站在线观看| 日本精品视频网站| 成人h动漫免费观看网站| 一区不卡字幕| 男男视频亚洲欧美| 国产综合精品在线| 欧美色另类天堂2015| 黄色福利在线观看| 久99久在线视频| 国产aⅴ精品一区二区四区| 日韩aⅴ视频一区二区三区| 亚洲精选91| 国产欧美视频一区| 亚洲精品中文字幕在线观看| 中文字幕在线播放不卡| 一道本无吗dⅴd在线播放一区| 黄在线观看免费网站ktv| 国产精品手机视频| 亚洲大胆av| 国产精品成人99一区无码| 亚洲一区二区欧美日韩| 99久久久久久久| 久久亚洲欧美日韩精品专区| 日韩毛片免费看| 亚洲AV无码成人精品一区| 韩国毛片一区二区三区| www.av免费| 91精品国产91久久久久久一区二区 | 放荡的美妇在线播放| 这里只有精品99re| 黄网页免费在线观看| 91亚洲精品久久久| 欧美国产一级| 亚洲性图第一页| 亚洲国产精品久久人人爱| 日韩在线观看视频一区| 91福利视频网| 国产精品欧美三级在线观看| 四虎永久在线精品无码视频| 国产日产精品一区| 亚洲系列第一页| 欧美成年人视频网站欧美| 久久视频社区| 一卡二卡三卡视频| 国产成人精品免费网站| www.av视频| 日韩成人在线视频| 亚洲综合电影| 亚州欧美一区三区三区在线| 国产一区在线不卡| 伊人365影院| 亚洲欧美国产另类| 农村妇女一区二区| 免费看日本黄色| www亚洲一区| 91好色先生tv| 欧美国产视频日韩| 九九精品在线| www激情五月| 天天爽夜夜爽夜夜爽精品视频| 人成免费电影一二三区在线观看| 国产精品免费久久久| 黄色av日韩| 国产99在线 | 亚洲| 91精品国产色综合久久久蜜香臀| 阿v视频在线观看| 艳色歌舞团一区二区三区|