溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶(hù)服務(wù)條款》

mysql中的Cache和Buffer的區(qū)別是什么

發(fā)布時(shí)間:2020-06-29 13:42:24 來(lái)源:億速云 閱讀:394 作者:Leah 欄目:MySQL數(shù)據(jù)庫(kù)

mysql中的Cache和Buffer的區(qū)別是什么?針對(duì)這個(gè)問(wèn)題,這篇文章詳細(xì)介紹了相對(duì)應(yīng)的分析和解答,希望可以幫助更多想解決這個(gè)問(wèn)題的小伙伴找到更簡(jiǎn)單易行的方法。

mysql Cache和Buffer區(qū)別有:

Buffer的核心作用是用來(lái)緩沖,緩和沖擊。比如你每秒要寫(xiě)100次硬盤(pán),對(duì)系統(tǒng)沖擊很大,浪費(fèi)了大量時(shí)間在忙著處理開(kāi)始寫(xiě)和結(jié)束寫(xiě)這兩件事嘛。用個(gè)buffer暫存起來(lái),變成每10秒寫(xiě)一次硬盤(pán),對(duì)系統(tǒng)的沖擊就很小,寫(xiě)入效率高了,日子過(guò)得爽了。極大緩和了沖擊。

Cache的核心作用是加快取用的速度。比如你一個(gè)很復(fù)雜的計(jì)算做完了,下次還要用結(jié)果,就把結(jié)果放手邊一個(gè)好拿的地方存著,下次不用再算了。加快了數(shù)據(jù)取用的速度。

所以,如果你注意關(guān)心過(guò)存儲(chǔ)系統(tǒng)的話(huà),你會(huì)發(fā)現(xiàn)硬盤(pán)的讀寫(xiě)緩沖/緩存名稱(chēng)是不一樣的,叫write-bufferread-cache。很明顯地說(shuō)出了兩者的區(qū)別。

當(dāng)然很多時(shí)候宏觀上說(shuō)兩者可能是混用的。比如實(shí)際上memcached很多人就是拿來(lái)讀寫(xiě)都用的。不少時(shí)候Non-SQL數(shù)據(jù)庫(kù)也是。嚴(yán)格來(lái)說(shuō),CPU里的L2和L3 Cache也都是讀寫(xiě)兼用——因?yàn)槟銢](méi)法簡(jiǎn)單地定義CPU用它們的方法是讀還是寫(xiě)。硬盤(pán)里也是個(gè)典型例子,buffer和cache都在一塊空間上,到底是buffer還是cache?

不過(guò)仔細(xì)想一下,你說(shuō)拿cache做buffer用行不行?當(dāng)然行,只要能控制cache淘汰邏輯就沒(méi)有任何問(wèn)題。

那么拿buffer做cache用呢?貌似在很特殊的情況下,能確定訪問(wèn)順序的時(shí)候,也是可以的。簡(jiǎn)單想一下就明白——buffer根據(jù)定義,需要隨機(jī)存儲(chǔ)嗎?一般是不需要的。但cache一定要。所以大多數(shù)時(shí)候用cache代替buffer可以,反之就比較局限。這也是技術(shù)上說(shuō)cache和buffer的關(guān)鍵區(qū)別。

補(bǔ)充1:

不要誤解Buffer就是用來(lái)寫(xiě)的,Cache就是用來(lái)讀的。讀可以用Buffer嗎?當(dāng)然可以,比如你想一批一批地處理讀取而非有啥處理啥的時(shí)候,就可以用讀buffer。寫(xiě)當(dāng)然也可以用cache,比如你的寫(xiě)入有很高的隨機(jī)性的時(shí)候。具體什么場(chǎng)景用Buffer什么場(chǎng)景用Cache要根據(jù)場(chǎng)景的具體需要決定。

補(bǔ)充2:

不要誤解Cache或Buffer就一定是內(nèi)存或者存在什么高速媒介上的東西。只要相對(duì)高速即可。我完全可以在硬盤(pán)上存Cache,比如有些游戲會(huì)在運(yùn)行時(shí)建立預(yù)編譯的shader(暴露年齡),這本質(zhì)上就是一種cache,它存在速度緩慢的硬盤(pán)上,因?yàn)樽x硬盤(pán)依舊比重新編譯要快。Buffer也同理,例如NTFS文件系統(tǒng)自己就有Logging Buffer,這個(gè)甚至明確拒絕放在任何易失緩存里。

關(guān)于mysql中的Cache和Buffer的區(qū)別是什么問(wèn)題的解答就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,如果你還有很多疑惑沒(méi)有解開(kāi),可以關(guān)注億速云行業(yè)資訊頻道了解更多相關(guān)知識(shí)。

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI