亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Mysql數(shù)據(jù)庫緩沖池詳解(Buffer pool)

 更新時間:2024年12月25日 10:11:49   作者:明礬java  
InnoDB存儲引擎通過BufferPool緩存數(shù)據(jù)頁和索引頁,減少磁盤I/O,提升查詢性能,BufferPool通過預(yù)讀和checkpoint機制優(yōu)化I/O操作和數(shù)據(jù)持久化

Buffer pool的作用

InnoDB 存儲引擎是以頁為單位來管理存儲空間的,我們進行的增刪改查操作其實本質(zhì)上都是在訪問頁面(包括讀頁面、寫頁面、創(chuàng)建新頁面等操作)。

而磁盤 I/O 需要消耗的時間很多,而在內(nèi)存中進行操作,效率則會高很多,為了能讓數(shù)據(jù)表或者索引中的數(shù)據(jù)隨時被我們所用,DBMS 會申請占用內(nèi)存來作為數(shù)據(jù)緩沖池 ,在真正訪問頁面之前,需要把在磁盤上的頁緩存到內(nèi)存中的 Buffer Pool 之后才可以訪問。

這樣做的好處是可以讓磁盤活動最小化,從而 減少與磁盤直接進行 I/O 的時間。

要知道,這種策略對提升 SQL 語句的查詢性能來說至關(guān)重要

如果索引的數(shù)據(jù)在緩沖池里,那么訪問的成本就會降低很多。

即申請一塊內(nèi)存提前從磁盤中讀取數(shù)據(jù)到內(nèi)存,后續(xù)mysql訪問數(shù)據(jù)都從Buffer pool 這個緩沖池里訪問,減少了磁盤IO的次數(shù),提高查詢效率。

緩沖池(Buffer Pool)

在 InnoDB 存儲引擎中有一部分數(shù)據(jù)會放到內(nèi)存中,緩沖池則占了這部分內(nèi)存的大部分,它用來存儲各種數(shù)據(jù)的緩存,由下圖可以看到 InnoDB 緩沖池包括了數(shù)據(jù)頁、索引頁、插入緩沖、鎖信息、自適應(yīng) Hash 和數(shù)據(jù)字典信息等。

緩存原則

位置 * 頻次”這個原則,可以幫我們對 I/O 訪問效率進行優(yōu)化。

首先,位置決定效率,提供緩沖池就是為了在內(nèi)存中可以直接訪問數(shù)據(jù)。

其次,頻次決定優(yōu)先級順序。因為緩沖池的大小是有限的,比如磁盤有 200G,但是內(nèi)存只有 16G,緩沖池大小只有 1G,就無法將所有數(shù)據(jù)都加載到緩沖池里,這時就涉及到優(yōu)先級順序,會優(yōu)先對使用頻次高的熱數(shù)據(jù)進行加載。

緩沖池的預(yù)讀特性

緩沖池的作用就是提升 I/O 效率,而我們進行讀取數(shù)據(jù)的時候存在一個“局部性原理”,也就是說我們使用了一些數(shù)據(jù),大概率還會使用它周圍的一些數(shù)據(jù),因此采用“預(yù)讀”的機制提前加載,可以減少未來可能的磁盤 I/O 操作。

緩沖池如何讀取數(shù)據(jù)

緩沖池管理器會盡量將經(jīng)常使用的數(shù)據(jù)保存起來,在數(shù)據(jù)庫進行頁面讀操作的時候,首先會判斷該頁面 是否在緩沖池中,如果存在就直接讀取,如果不存在,就會通過內(nèi)存或磁盤將頁面存放到緩沖池中再進行讀取。

緩存在數(shù)據(jù)庫中的結(jié)構(gòu)和作用如下圖所示:

mysql通過存儲引擎讀取到緩沖池,再從緩沖池讀取數(shù)據(jù),緩沖池就是媒介。

如果我們執(zhí)行 SQL 語句的時候更新了緩存池中的數(shù)據(jù),那么這些數(shù)據(jù)會馬上同步到磁盤上嗎?

實際上,當我們對數(shù)據(jù)庫中的記錄進行修改的時候,首先會修改緩沖池中頁里面的記錄信息,然后數(shù)據(jù)庫會以一定的頻率刷新到磁盤中。注意并不是每次發(fā)生更新操作,都會立即進行磁盤回寫。

緩沖池會采用一種叫做checkpoint的機制 將數(shù)據(jù)回寫到磁盤上,這樣做的好處就是提升了數(shù)據(jù)庫的整體性能。

比如,當緩沖池不夠用時,需要釋放掉一些不常用的頁,此時就可以強行采用checkpoint的方式,將不常用的臟頁回寫到磁盤上,然后再從緩存池中將這些頁釋放掉。

這里的臟頁 (dirty page) 指的是緩沖池中被修改過的頁,與磁盤上的數(shù)據(jù)頁不一致。

總結(jié)

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • MySQL綠色版設(shè)置編碼以及1067錯誤詳解

    MySQL綠色版設(shè)置編碼以及1067錯誤詳解

    這篇文章主要介紹了MySQL綠色版設(shè)置編碼,以及1067錯誤的相關(guān)資料,需要的朋友可以參考下
    2017-05-05
  • mysql split函數(shù)用逗號分隔的實現(xiàn)

    mysql split函數(shù)用逗號分隔的實現(xiàn)

    這篇文章主要介紹了mysql split函數(shù)用逗號分隔的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-10-10
  • mysql中l(wèi)ike % %模糊查詢的實現(xiàn)

    mysql中l(wèi)ike % %模糊查詢的實現(xiàn)

    這篇文章主要介紹了mysql中l(wèi)ike % %模糊查詢的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-12-12
  • Mysql實現(xiàn)增量恢復的方法詳解

    Mysql實現(xiàn)增量恢復的方法詳解

    本文給大家分享的是如何實現(xiàn)mysql增量恢復的場景以及具體實現(xiàn)方法,有需要的小伙伴可以參考下
    2018-07-07
  • MySQL中怎么匹配年月

    MySQL中怎么匹配年月

    一般數(shù)據(jù)庫中給到的時間都是年-月-日形式的,那怎么匹配年-月/的形式呢,下面通過實例代碼介紹怎么在數(shù)據(jù)庫中查詢到關(guān)于2021年8月的數(shù)據(jù),對mysql匹配年月相關(guān)知識,感興趣的朋友跟隨小編一起看看吧
    2024-04-04
  • MySQL日期格式以及日期函數(shù)舉例詳解

    MySQL日期格式以及日期函數(shù)舉例詳解

    這篇文章主要給大家介紹了關(guān)于MySQL日期格式及日期函數(shù)的相關(guān)資料,日期在數(shù)據(jù)庫中是一個常見且重要的數(shù)據(jù)類型,在MySQL中我們可以使用各種函數(shù)和格式化選項來處理和顯示日期,需要的朋友可以參考下
    2023-11-11
  • JDBC-idea導入mysql連接java的jar包(mac)的方法

    JDBC-idea導入mysql連接java的jar包(mac)的方法

    這篇文章主要介紹了JDBC-idea導入mysql連接java的jar包(mac)的方法,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-09-09
  • MySQL免安裝版(zip)安裝配置詳細教程

    MySQL免安裝版(zip)安裝配置詳細教程

    這篇文章主要為大家詳細介紹了MySQL免安裝版(zip)安裝配置詳細教程,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-08-08
  • MySQL5.7不停業(yè)務(wù)將傳統(tǒng)復制變更為GTID復制的實例

    MySQL5.7不停業(yè)務(wù)將傳統(tǒng)復制變更為GTID復制的實例

    下面小編就為大家?guī)硪黄狹ySQL5.7不停業(yè)務(wù)將傳統(tǒng)復制變更為GTID復制的實例。小編覺的挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-03-03
  • MySQL?中這么多索引該怎么選擇

    MySQL?中這么多索引該怎么選擇

    這篇文章主要介紹了MySQL?中這么多索引該怎么選擇,索引的本質(zhì)是存儲引擎用于快速查詢記錄的一種數(shù)據(jù)結(jié)構(gòu)。特別是數(shù)據(jù)表中數(shù)據(jù)特別多的時候,索引對于數(shù)據(jù)庫的性能就愈發(fā)重要,下文詳細相關(guān)內(nèi)容介紹,需要的小伙伴可以參考一下
    2022-09-09

最新評論