這篇具有很好參考價(jià)值的文章主要介紹了MySQL中的Buffer Pool。希望對(duì)大家有所幫助。如果存在錯(cuò)誤或未考慮完全的地方,請(qǐng)大家不吝賜教,您也可以點(diǎn)擊"舉報(bào)違法"按鈕提交疑問(wèn)。
一、概述
????????Buffer Pool是數(shù)據(jù)庫(kù)的一個(gè)內(nèi)存組件,里面緩存了磁盤上的真實(shí)數(shù)據(jù),然后我們的Java系統(tǒng)對(duì)數(shù)據(jù)庫(kù)執(zhí)行的增刪改操作,其實(shí)主要就是對(duì)這個(gè)內(nèi)存數(shù)據(jù)結(jié)構(gòu)中的緩存數(shù)據(jù)執(zhí)行的。我們先來(lái)看一下下面的圖,里面就畫(huà)了數(shù)據(jù)庫(kù)中的Buffer Pool內(nèi)存組件。
?二、數(shù)據(jù)頁(yè)
????????接著我們來(lái)看下一個(gè)問(wèn)題,假設(shè)現(xiàn)在我們的數(shù)據(jù)庫(kù)中一定有一片內(nèi)存區(qū)域是Buffer Pool了,那么我們的數(shù)據(jù)是如何放在Buffer Pool中的?
????????我們都知道數(shù)據(jù)庫(kù)的核心數(shù)據(jù)模型就是表+字段+行的概念,也就是說(shuō)我們都知道數(shù)據(jù)庫(kù)里有一個(gè)一個(gè)的表,一個(gè)表有很多字段,然后一個(gè)表里有很多行數(shù)據(jù),每行數(shù)據(jù)都有自己的字段值。所以大家覺(jué)得我們的數(shù)據(jù)是一行一行的放在Buffer Pool里面的嗎?
????????這就明顯不是了,實(shí)際上MySQL對(duì)數(shù)據(jù)抽象出來(lái)了一個(gè)數(shù)據(jù)頁(yè)的概念,他是把很多行數(shù)據(jù)放在了一個(gè)數(shù)據(jù)頁(yè)里,也就是說(shuō)我們的磁盤文件中就是會(huì)有很多的數(shù)據(jù)頁(yè),每一頁(yè)數(shù)據(jù)里放了很多行數(shù)據(jù),如下圖所示。

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

三、磁盤上的數(shù)據(jù)頁(yè)和Buffer Pool中的緩存頁(yè)是如何對(duì)應(yīng)起來(lái)的?
????????實(shí)際上默認(rèn)情況下,磁盤中存放的數(shù)據(jù)頁(yè)的大小是16KB,也就是說(shuō),一頁(yè)數(shù)據(jù)包含了16KB的內(nèi)容。
????????而B(niǎo)uffer Pool中存放的一個(gè)一個(gè)的數(shù)據(jù)頁(yè),我們通常叫做緩存頁(yè),因?yàn)楫吘笲uffer Pool是一個(gè)緩沖池,里面的數(shù)據(jù)都是從磁盤緩存到內(nèi)存去的。
????????而B(niǎo)uffer Pool中默認(rèn)情況下,一個(gè)緩存頁(yè)的大小和磁盤上的一個(gè)數(shù)據(jù)頁(yè)的大小是一一對(duì)應(yīng)起來(lái)的,都是16KB。
????????所以我們看下圖,我給圖中的Buffer Pool標(biāo)注出來(lái)了他的內(nèi)存大小,假設(shè)他是128MB吧,然后數(shù)據(jù)頁(yè)的大小是16KB。
文章來(lái)源:http://www.zghlxwxcb.cn/news/detail-677250.html
四、緩存頁(yè)對(duì)應(yīng)的描述信息是什么?
????????接著我們要了解下一個(gè)概念,對(duì)于每個(gè)緩存頁(yè),他實(shí)際上都會(huì)有一個(gè)描述信息,這個(gè)描述信息大體可以認(rèn)為是用來(lái)描述這個(gè)緩存頁(yè)的。
????????比如包含如下的一些東西:這個(gè)數(shù)據(jù)頁(yè)所屬的表空間、數(shù)據(jù)頁(yè)的編號(hào)、這個(gè)緩存頁(yè)在Buffer Pool中的地址以及別的一些雜七雜八的東西。
????????每個(gè)緩存頁(yè)都會(huì)對(duì)應(yīng)一個(gè)描述信息,這個(gè)描述信息本身也是一塊數(shù)據(jù),在Buffer Pool中,每個(gè)緩存頁(yè)的描述數(shù)據(jù)放在最前面, 然后各個(gè)緩存頁(yè)放在后面。所以此時(shí)我們看下面的圖,Buffer Pool實(shí)際看起來(lái)大概長(zhǎng)這個(gè)樣子。
文章來(lái)源地址http://www.zghlxwxcb.cn/news/detail-677250.html
到了這里,關(guān)于MySQL中的Buffer Pool的文章就介紹完了。如果您還想了解更多內(nèi)容,請(qǐng)?jiān)谟疑辖撬阉鱐OY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!
本文來(lái)自互聯(lián)網(wǎng)用戶投稿,該文觀點(diǎn)僅代表作者本人,不代表本站立場(chǎng)。本站僅提供信息存儲(chǔ)空間服務(wù),不擁有所有權(quán),不承擔(dān)相關(guān)法律責(zé)任。如若轉(zhuǎn)載,請(qǐng)注明出處: 如若內(nèi)容造成侵權(quán)/違法違規(guī)/事實(shí)不符,請(qǐng)點(diǎn)擊違法舉報(bào)進(jìn)行投訴反饋,一經(jīng)查實(shí),立即刪除!