MySQL InnoDB關(guān)鍵特性 插入緩沖/兩次寫/自適應(yīng)哈希索引等

一 插入緩沖

1.1 解決的問題

插入多條數(shù)據(jù)時有咨,除了需要插入聚集索引外,還需要插入到非聚集索引中,然而非聚集索引的插入走的是隨機寫,這個操作會影響性能锄列。

1.2 基本原理

插入非聚集索引時,不會直接寫到真正的非聚集索引里面去惯悠,而是先寫到一個叫插入緩沖的臨時文件中(注意插入緩沖雖然名字叫緩沖邻邮,實際上是臨時文件)

然后依賴后臺線程將插入緩沖中的內(nèi)容更新到真正的非聚集索引上去。

由于對插入緩沖的寫是連續(xù)的克婶,所以這種操作就解決了隨機寫的問題筒严。

1.3 使用條件

并不是所有對非聚集索引的更新都會使用插入緩沖,需要滿足以下兩個條件:

  • 非聚集索引不是唯一的
  • 要插入的非聚集索引頁不在內(nèi)存中

為什么不能是唯一索引的情萤?

因為如果是唯一索引鸭蛙,則插入的時候就需要判斷是否有重復(fù),而這個判斷的過程本身就包含一次隨機讀筋岛,所以即使使用了插入緩沖也無法解決磁盤隨機讀寫的問題

為什么非聚集索引頁不能在內(nèi)存中娶视?

其實并不是非聚集索引頁不能在內(nèi)存中,而是在內(nèi)存中的非聚集索引頁就不需要走插入緩沖了泉蝌。因為如果在內(nèi)存中的話歇万,那直接寫內(nèi)存中的緩存頁即可揩晴。

這里可能還會有疑問,寫了內(nèi)存中的緩存頁后贪磺,把緩存頁刷新到磁盤時不是也會隨機寫磁盤嗎硫兰?

其實不是的,內(nèi)存中的緩存頁被更新后不會立即刷新到磁盤中寒锚,而是等待后臺線程刷新劫映。所以這里也不會隨機讀寫磁盤。

可能還會有疑問刹前,如果內(nèi)存中的緩存頁被更新后不直接刷新到磁盤泳赋,那么宕機時豈不是會丟失數(shù)據(jù)嗎?

其實這里也不會喇喉,因為在寫內(nèi)存中的緩存頁時會先寫重做日志祖今,記錄更新的內(nèi)容,而這個重做日志是會在事務(wù)提交前就刷新到磁盤中的拣技,所以即使宕機千诬,也可以用重做日志恢復(fù)數(shù)據(jù)。另外重做日志也是磁盤上連續(xù)的空間膏斤,所以也不會有隨機讀寫

二 兩次寫

2.1 解決的問題

當(dāng)數(shù)據(jù)庫寫物理頁時徐绑,如果宕機了,那么可能會導(dǎo)致物理頁的一致性被破壞莫辨。

可能有人會說傲茄,重做日志不是可以恢復(fù)物理頁嗎?實際上是的沮榜,但是要求是在物理頁一致的情況下盘榨。

也就是說,如果物理頁完全是未寫之前的狀態(tài)敞映,則可以用重做日志恢復(fù)较曼。如果物理頁已經(jīng)完全寫完了,那么也可以用重做日志恢復(fù)振愿。但是如果物理頁前面2K寫了新的數(shù)據(jù),但是后面2K還是舊的數(shù)據(jù)弛饭,則種情況下就無法使用重做日志恢復(fù)了冕末。

這里的兩次寫就是保證了物理頁的一致性,使得即使宕機侣颂,也可以用重做日志恢復(fù)档桃。

2.2 基本原理

在寫物理頁時,并不是直接寫到真正的物理寫上去憔晒,而是先寫到一個臨時頁上去藻肄,臨時頁寫完后蔑舞,再寫物理頁。

這樣一來:

  • 如果寫臨時頁時宕機了嘹屯,物理頁還是完全未寫之前的狀態(tài)攻询,可以用重做日志恢復(fù)
  • 如果寫物理頁時宕機了,則可以使用臨時頁來恢復(fù)物理頁

2.3 具體實現(xiàn)

  • InnoDB中共享表空間中劃了2M的空間州弟,叫做double write钧栖,專門存放臨時頁。
  • InnoDB還從內(nèi)存中劃出了2M的緩存空間婆翔,叫做double write buffer拯杠,專門緩存臨時頁
  • 每次寫物理頁時,先寫到double write buffer中啃奴,然后從double write buffer寫到double write上去潭陪。最后再從double write buffer寫到物理頁上去

你問我為什么要有 double write buffer 這個東西?其實吧InnoDB里面物理頁都 會有內(nèi)存緩存最蕾。只是這里單把這2M的緩存取了個名字而已依溯。

三 自適應(yīng)哈希索引

InnoDB自動監(jiān)控對索引的查找,如果發(fā)現(xiàn)建立哈希索引可以提高效率揖膜,則會自動建立

可以使用innodb_adaptive_hash_index來啟用或者關(guān)閉誓沸,默認是開啟的

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市壹粟,隨后出現(xiàn)的幾起案子拜隧,更是在濱河造成了極大的恐慌,老刑警劉巖趁仙,帶你破解...
    沈念sama閱讀 212,718評論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件洪添,死亡現(xiàn)場離奇詭異,居然都是意外死亡雀费,警方通過查閱死者的電腦和手機干奢,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,683評論 3 385
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來盏袄,“玉大人忿峻,你說我怎么就攤上這事≡穑” “怎么了逛尚?”我有些...
    開封第一講書人閱讀 158,207評論 0 348
  • 文/不壞的土叔 我叫張陵,是天一觀的道長刁愿。 經(jīng)常有香客問我绰寞,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,755評論 1 284
  • 正文 為了忘掉前任滤钱,我火速辦了婚禮觉壶,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘件缸。我一直安慰自己铜靶,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 65,862評論 6 386
  • 文/花漫 我一把揭開白布停团。 她就那樣靜靜地躺著旷坦,像睡著了一般。 火紅的嫁衣襯著肌膚如雪佑稠。 梳的紋絲不亂的頭發(fā)上秒梅,一...
    開封第一講書人閱讀 50,050評論 1 291
  • 那天,我揣著相機與錄音舌胶,去河邊找鬼捆蜀。 笑死,一個胖子當(dāng)著我的面吹牛幔嫂,可吹牛的內(nèi)容都是我干的辆它。 我是一名探鬼主播,決...
    沈念sama閱讀 39,136評論 3 410
  • 文/蒼蘭香墨 我猛地睜開眼履恩,長吁一口氣:“原來是場噩夢啊……” “哼锰茉!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起切心,我...
    開封第一講書人閱讀 37,882評論 0 268
  • 序言:老撾萬榮一對情侶失蹤飒筑,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后绽昏,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體协屡,經(jīng)...
    沈念sama閱讀 44,330評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,651評論 2 327
  • 正文 我和宋清朗相戀三年全谤,在試婚紗的時候發(fā)現(xiàn)自己被綠了肤晓。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 38,789評論 1 341
  • 序言:一個原本活蹦亂跳的男人離奇死亡认然,死狀恐怖补憾,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情卷员,我是刑警寧澤余蟹,帶...
    沈念sama閱讀 34,477評論 4 333
  • 正文 年R本政府宣布,位于F島的核電站子刮,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜挺峡,卻給世界環(huán)境...
    茶點故事閱讀 40,135評論 3 317
  • 文/蒙蒙 一葵孤、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧橱赠,春花似錦尤仍、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,864評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至饼拍,卻和暖如春赡模,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背师抄。 一陣腳步聲響...
    開封第一講書人閱讀 32,099評論 1 267
  • 我被黑心中介騙來泰國打工漓柑, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人叨吮。 一個月前我還...
    沈念sama閱讀 46,598評論 2 362
  • 正文 我出身青樓辆布,卻偏偏與公主長得像,于是被迫代替她去往敵國和親茶鉴。 傳聞我的和親對象是個殘疾皇子锋玲,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 43,697評論 2 351

推薦閱讀更多精彩內(nèi)容