欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

MySQL中Buffer?Pool內(nèi)存結(jié)構(gòu)詳情

 更新時間:2022年09月25日 16:40:58   作者:zht245648124  
這篇文章主要介紹了MySQL中Buffer?Pool內(nèi)存結(jié)構(gòu)詳情,文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下

1、回顧一下Buffer Pool是個什么東西?

1.1 增刪改直接操作的是內(nèi)存還是磁盤?

現(xiàn)在我們先來回顧一下數(shù)據(jù)庫中的Buffer Pool是個什么東西?其實(shí)他是一個非常關(guān)鍵的組件,因?yàn)槲覀兺ㄟ^之前的講解都知道一點(diǎn),那就是數(shù)據(jù)庫中的數(shù)據(jù)實(shí)際上最終都是要存放在磁盤文件上的。

我們在對數(shù)據(jù)庫執(zhí)行增刪改操作的時候,不可能直接更新磁盤上的數(shù)據(jù)的,因?yàn)槿绻銓Υ疟P進(jìn)行隨機(jī)讀寫操作,那速度是相當(dāng)?shù)穆?,隨便一個大磁盤文件的隨機(jī)讀寫操作,可能都要幾百毫秒。如果要是那么搞的話,可能你的數(shù)據(jù)庫每秒也就只能處理幾百個請求了!

之前我們也都講解過了,你在對數(shù)據(jù)庫執(zhí)行增刪改操作的時候,實(shí)際上主要都是針對內(nèi)存里的Buffer Pool中的數(shù)據(jù)進(jìn)行的,也就是你實(shí)際上主要是對數(shù)據(jù)庫的內(nèi)存里的數(shù)據(jù)結(jié)構(gòu)進(jìn)行了增刪改,如下圖所示。

1.2 數(shù)據(jù)庫崩潰了,內(nèi)存中數(shù)據(jù)丟了怎么辦?

當(dāng)然,我們之前都說過,其實(shí)每個人都擔(dān)心一個事,就是你在數(shù)據(jù)庫的內(nèi)存里執(zhí)行了一堆增刪改的操作,內(nèi)存數(shù)據(jù)是更新了,但是這個時候如果數(shù)據(jù)庫突然崩潰了,那么內(nèi)存里更新好的數(shù)據(jù)不是都沒了嗎?

所以其實(shí)之前我們就用了很多章節(jié)講這個問題,MySQL就怕這個問題,所以引入了一個redo log機(jī)制,你在對內(nèi)存里的數(shù)據(jù)進(jìn)行增刪改的時候,同時會把增刪改對應(yīng)的日志寫入redo log中,如下圖。

萬一你的數(shù)據(jù)庫突然崩潰了,沒關(guān)系,只要從redo log日志文件里讀取出來你之前做過哪些增刪改操作,瞬間就可以重新把這些增刪改操作在你的內(nèi)存里執(zhí)行一遍,這就可以恢復(fù)出來你之前做過哪些增刪改操作了。

當(dāng)然對于數(shù)據(jù)更新的過程,是有一套嚴(yán)密的步驟的,還涉及到undo log、binlog、提交事務(wù)、buffer pool臟數(shù)據(jù)刷回磁盤等等。我們之前都講過了,這里不再重復(fù),這里僅僅是回顧一下數(shù)據(jù)庫中的Buffer Pool這個東西。

1.3 Buffer Pool的一句話總結(jié)

所以這里我們簡單對Buffer Pool這個東西做一下總結(jié),他其實(shí)是數(shù)據(jù)庫中我們第一個必須要搞清楚的核心組件,因?yàn)樵鰟h改操作首先就是針對這個內(nèi)存中的Buffer Pool里的數(shù)據(jù)執(zhí)行的,同時配合了后續(xù)的redo log、刷磁盤等機(jī)制和操作。

所以Buffer Pool就是數(shù)據(jù)庫的一個內(nèi)存組件,里面緩存了磁盤上的真實(shí)數(shù)據(jù),然后我們的Java系統(tǒng)對數(shù)據(jù)庫執(zhí)行的增刪改操作,其實(shí)主要就是對這個內(nèi)存數(shù)據(jù)結(jié)構(gòu)中的緩存數(shù)據(jù)執(zhí)行的。

2、Buffer Pool這個內(nèi)存數(shù)據(jù)結(jié)構(gòu)到底長個什么樣子?

我們先來看一下下面的圖,里面就畫了數(shù)據(jù)庫中的Buffer Pool內(nèi)存組件。

2.1 如何配置MySQL的Buffer Pool的大小?

我們先來看一下下面的圖,里面就畫了數(shù)據(jù)庫中的Buffer Pool內(nèi)存組件。
因?yàn)锽uffer Pool本質(zhì)其實(shí)就是數(shù)據(jù)庫的一個內(nèi)存組件,你可以理解為他就是一片內(nèi)存數(shù)據(jù)結(jié)構(gòu),所以這個內(nèi)存數(shù)據(jù)結(jié)構(gòu)肯定是有一定的大小的,不可能是無限大的。

這個Buffer Pool默認(rèn)情況下是128MB,還是有一點(diǎn)偏小了,我們實(shí)際生產(chǎn)環(huán)境下完全可以對Buffer Pool進(jìn)行調(diào)整。比如我們的數(shù)據(jù)庫如果是16核32G的機(jī)器,那么你就可以給Buffer Pool分配個2GB的內(nèi)存,使用下面的配置就可以了。

[server]
innodb_buffer_pool_size = 2147483648

2.2 數(shù)據(jù)頁

在將Buffer Pool之前,我們先來了解一個概念:數(shù)據(jù)頁。想必好多人也聽說過這個,但是數(shù)據(jù)頁是個什么樣的結(jié)構(gòu)呢?存放的是什么樣的數(shù)據(jù)呢?別急,下面會慢慢道來。

接著我們來看下一個問題,假設(shè)現(xiàn)在我們的數(shù)據(jù)庫中一定有一片內(nèi)存區(qū)域是Buffer Pool了,那么我們的數(shù)據(jù)是如何放在Buffer Pool中的?

也就是說我們都知道數(shù)據(jù)庫里有一個一個的表,一個表有很多字段,然后一個表里有很多行數(shù)據(jù),每行數(shù)據(jù)都有好多的字段值。所以大家覺得我們的數(shù)據(jù)是一行一行的放在Buffer Pool里面的嗎?

這就明顯不是了,實(shí)際上MySQL對數(shù)據(jù)抽象出來了一個數(shù)據(jù)頁的概念,是把很多行數(shù)據(jù)放在了一個數(shù)據(jù)頁里,也就是說我們的磁盤文件中就是會有很多的數(shù)據(jù)頁,每一頁數(shù)據(jù)里放了很多行數(shù)據(jù)。

所以實(shí)際上假設(shè)我們要更新一行數(shù)據(jù),此時數(shù)據(jù)庫會找到這行數(shù)據(jù)所在的數(shù)據(jù)頁,不是只加載一行數(shù)據(jù),而是從磁盤文件里把這行數(shù)據(jù)所在的數(shù)據(jù)頁直接給加載到Buffer Pool里去。也就是說,Buffer Pool中存放的也是一個一個的數(shù)據(jù)頁,如下圖:

2.3 磁盤上的數(shù)據(jù)頁和Buffer Pool中的數(shù)據(jù)頁是如何對應(yīng)起來的?

  • 實(shí)際上默認(rèn)情況下,磁盤中存放的數(shù)據(jù)頁的大小是16KB,也就是說,一頁數(shù)據(jù)包含了16KB的內(nèi)容。
  • 而Buffer Pool中存放的一個一個的數(shù)據(jù)頁,我們通常叫做緩存頁,因?yàn)楫吘笲uffer Pool是一個緩沖池,里面的數(shù)據(jù)都是從磁盤緩存到內(nèi)存去的。
  • 而Buffer Pool中默認(rèn)情況下,一個緩存頁的大小和磁盤上的一個數(shù)據(jù)頁的大小是一一對應(yīng)起來的,都是16KB。

所以我們看下圖,圖中的Buffer Pool標(biāo)注出來了的內(nèi)存大小,假設(shè)是128MB吧,然后數(shù)據(jù)頁的大小是16KB。

2.4 緩存頁描述信息

接著我們要了解下一個概念,對于每個緩存頁,實(shí)際上都會有一個描述信息,這個描述信息大體可以認(rèn)為是用來描述這個緩存頁的
比如包含如下的一些東西:這個數(shù)據(jù)頁所屬的表空間、數(shù)據(jù)頁的編號、這個緩存頁在Buffer Pool中的內(nèi)存地址以及別的一些東西,就相當(dāng)于緩存頁的元數(shù)據(jù)一樣。

每個緩存頁都會對應(yīng)一個描述信息,這個描述信息本身也是一塊數(shù)據(jù),在Buffer Pool中,每個緩存頁的描述數(shù)據(jù)放在最前面,然后各個緩存頁放在后面。

所以此時我們看下面的圖,Buffer Pool實(shí)際看起來大概長這個樣子。

而且這里我們要注意一點(diǎn),Buffer Pool中的描述數(shù)據(jù)大概相當(dāng)于緩存頁大小的5%左右,也就是每個描述數(shù)據(jù)大概是800個字節(jié)左右的大小,然后假設(shè)你設(shè)置的buffer pool大小是128MB,實(shí)際上Buffer Pool真正的最終大小會超出一些,可能有個130多MB的樣子,因?yàn)樗锩孢€要存放每個緩存頁的描述數(shù)據(jù)

到此這篇關(guān)于MySQL中Buffer Pool內(nèi)存結(jié)構(gòu)詳情的文章就介紹到這了,更多相關(guān)MySQL Buffer Pool內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 登錄mysql數(shù)據(jù)庫的幾種方式

    登錄mysql數(shù)據(jù)庫的幾種方式

    本文主要介紹了登錄mysql數(shù)據(jù)庫的幾種方式,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-05-05
  • MySQL主從復(fù)制原理詳情

    MySQL主從復(fù)制原理詳情

    這篇文章主要介紹了MySQL主從復(fù)制原理詳情,MySQL?主從復(fù)制是指數(shù)據(jù)可以從一個MySQL數(shù)據(jù)庫服務(wù)器主節(jié)點(diǎn)復(fù)制到一個或多個從節(jié)點(diǎn),文章圍繞主題展開詳細(xì)的內(nèi)容介紹。感興趣的小伙伴可以參考一下
    2022-06-06
  • MySql中深度分頁的問題處理

    MySql中深度分頁的問題處理

    這篇文章主要介紹了MySql中深度分頁的問題處理,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-05-05
  • MySQL 5.7常見數(shù)據(jù)類型

    MySQL 5.7常見數(shù)據(jù)類型

    這篇文章主要介紹了MySQL 5.7數(shù)據(jù)類型詳解,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-07-07
  • MySQL表的內(nèi)外連接和視圖使用實(shí)戰(zhàn)練習(xí)

    MySQL表的內(nèi)外連接和視圖使用實(shí)戰(zhàn)練習(xí)

    這篇文章主要給大家介紹了關(guān)于MySQL表的內(nèi)外連接和視圖使用的相關(guān)資料,MySQL的內(nèi)外連接查詢是用于將兩個或多個表中的數(shù)據(jù)進(jìn)行關(guān)聯(lián)查詢的一種方法,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2024-01-01
  • Ubuntu自啟動Mysql的三種方式

    Ubuntu自啟動Mysql的三種方式

    本文給大家介紹ubuntu自啟動mysql的三種方式,一種方法通過執(zhí)行命令,也是最簡單的方法,第二種方法是使用sysv-rc-cont工具,第三種方法是使用chkconfig工具,關(guān)于以上三種方式的詳解請看下文
    2015-10-10
  • MySQL里面的子查詢實(shí)例

    MySQL里面的子查詢實(shí)例

    最近學(xué)習(xí)php+mysql執(zhí)行操作,發(fā)現(xiàn)了這一篇實(shí)例代碼
    2008-04-04
  • MySQL日志管理詳解

    MySQL日志管理詳解

    這篇文章主要介紹了MySQL日志管理詳解,本文講解了日志種類、日志功能、MySQL中日志相關(guān)常用的服務(wù)器變量說明等內(nèi)容,需要的朋友可以參考下
    2015-07-07
  • 一文搞懂MySQL索引特性(清晰明了)

    一文搞懂MySQL索引特性(清晰明了)

    索引可以提高數(shù)據(jù)庫的性能,提高一個海量數(shù)據(jù)的檢索速度,但是插入,更新,刪除的速度相應(yīng)會降低,下面這篇文章主要給大家介紹了關(guān)于MySQL索引特性的相關(guān)資料,需要的朋友可以參考下
    2023-04-04
  • MySQL中幾種常見的嵌套查詢詳解

    MySQL中幾種常見的嵌套查詢詳解

    最近在MySQL上做了點(diǎn)工作,發(fā)現(xiàn)很多人都在詢問MySQL嵌套查詢的問題,下面這篇文章主要給大家介紹了關(guān)于MySQL中幾種常見的嵌套查詢,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-08-08

最新評論