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

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

網(wǎng)站建設(shè)哪家好,找創(chuàng)新互聯(lián)建站!專注于網(wǎng)頁設(shè)計、網(wǎng)站建設(shè)、微信開發(fā)、微信小程序開發(fā)、集團企業(yè)網(wǎng)站建設(shè)等服務項目。為回饋新老客戶創(chuàng)新互聯(lián)還提供了全椒免費建站歡迎大家使用!

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

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

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

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

當然很多時候宏觀上說兩者可能是混用的。比如實際上memcached很多人就是拿來讀寫都用的。不少時候Non-SQL數(shù)據(jù)庫也是。嚴格來說,CPU里的L2和L3 Cache也都是讀寫兼用——因為你沒法簡單地定義CPU用它們的方法是讀還是寫。硬盤里也是個典型例子,buffer和cache都在一塊空間上,到底是buffer還是cache?

不過仔細想一下,你說拿cache做buffer用行不行?當然行,只要能控制cache淘汰邏輯就沒有任何問題。

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

補充1:

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

補充2:

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

關(guān)于mysql中的Cache和Buffer的區(qū)別是什么問題的解答就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道了解更多相關(guān)知識。

新聞名稱:mysql中的Cache和Buffer的區(qū)別是什么
地址分享:http://bm7419.com/article36/iicosg.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供微信公眾號、網(wǎng)頁設(shè)計公司、動態(tài)網(wǎng)站商城網(wǎng)站、全網(wǎng)營銷推廣、網(wǎng)站營銷

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

成都seo排名網(wǎng)站優(yōu)化