在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

Buffer和Cache的定義

馬哥Linux運維 ? 來源:馬哥Linux運維 ? 作者:馬哥Linux運維 ? 2022-05-13 09:53 ? 次閱讀

BufferCache 的定義:

  • Buffer:是原始磁盤塊的臨時存儲,即將緩存數(shù)據(jù)寫入磁盤。它通常不會很大(大約 20MB)。這樣,內核就可以將分散的寫入集中起來,從而對磁盤寫入進行統(tǒng)一優(yōu)化。例如,多個小的寫入可以合并為一個大的寫入等。

  • Cache:是用于從磁盤讀取文件的頁面緩存,用于緩存從文件中讀取的數(shù)據(jù)。這樣,下次訪問這些文件數(shù)據(jù)時,可以直接從內存中快速取回,而無需再次訪問緩慢的磁盤。

但是讓我問你,由于 Buffer 只是將寫入磁盤的數(shù)據(jù)的緩存。反過來,它還會緩存從磁盤讀取的數(shù)據(jù)嗎?或者 Cache 是從文件中讀取數(shù)據(jù)的緩存,那么它是否也為寫入文件緩存數(shù)據(jù)呢?

如果你能回答以上兩個問題,你可以跳過這篇文章,我想你已經對 BufferCache 有了很好的理解。但如果你不能,請留下來看看我的進一步解釋。

free 命令

要檢查系統(tǒng)內存使用情況,您想到的第一個命令可能是 free ,例如:

$free-h
totalusedfreesharedbuff/cacheavailable
Mem:1.9G1.0G394M2.6M491M728M
Swap:0B0B0B

很明顯,該輸出包括了物理內存 MemSwap 的具體使用情況(如總內存、已用內存、緩存、可用內存等)。緩存是 BufferCache 兩部分的總和。

讓我們看一下 free 的手冊頁中的 BufferCache 定義:

buffers
Memoryusedbykernelbuffers(Buffersin/proc/meminfo)
cacheMemoryusedbythepagecacheandslabs(CachedandSReclaimablein/proc/meminfo)
buff/cache
Sumofbuffersandcache

我們可以看到 free 命令的源數(shù)據(jù)實際上存儲在 proc/meminfo 文件中。正如我前面提到的,/procLinux 內核提供的一個特殊的文件系統(tǒng),它就像一個用戶與內核交互的接口

/proc 文件系統(tǒng)也是許多性能工具的最終數(shù)據(jù)源。在 man proc 中,BuffersCached 的定義如下:

Buffers%lu
Relativelytemporarystorageforrawdiskblocksthatshouldn'tgettremendouslylarge(20MBorso).
Cached%lu
In-memorycacheforfilesreadfromthedisk(thepagecache).Doesn'tincludeSwapCached.
...
SReclaimable%lu(sinceLinux2.6.19)
PartofSlab,thatmightbereclaimed,suchascaches.

SUnreclaim%lu(sinceLinux2.6.19)
PartofSlab,thatcannotbereclaimedonmemorypressure.

至此,您可能認為您已經找到了我的問題的答案,“Buffer”只是用于將數(shù)據(jù)寫入磁盤的緩存,“Cache”只是用于從文件中讀取數(shù)據(jù)的緩存。但事實上,“Buffer”也可以用于讀取,“Cache”也可以用于寫入。

實驗

我們將在這里做兩個實驗,寫緩存和讀緩存。

寫入 Cache

讓我們登錄到我們的 Linux 主機并準備好兩個終端。在終端 1,讓我們先清理緩存

c2f2f4ae-d25e-11ec-bce3-dac502259ad0.png

這里 /proc/sys/vm/drop_caches 是一個通過 proc 文件系統(tǒng)修改內核行為的例子。寫入 3 意味著清理各種緩存,例如文件頁、目錄條目和 Inode。

仍然在終端 1,讓我們開啟 vmstat 2 命令:

c3058236-d25e-11ec-bce3-dac502259ad0.png
  • buffcache 就是我們前面看到的 BufferCache,單位是 KB。
  • bibo 分別表示塊設備讀取和寫入的大小,以塊/s 為單位。由于 Linux 中的塊大小為 1KB,因此這個單位相當于 KB/s。

接下來,轉移到終端 2 并運行以下命令:

c31a58e6-d25e-11ec-bce3-dac502259ad0.png

現(xiàn)在切換回終端 1,并觀察 buffcache 的變化:

c32ecd6c-d25e-11ec-bce3-dac502259ad0.png

通過觀察 vmstat 的輸出,我們發(fā)現(xiàn)運行 dd 命令時,Cache 一直在增長,而 Buffer 基本沒有變化。

讀取 Buffer

現(xiàn)在,讓我們做第二個實驗。再次清除終端 1中的緩存

c34774d4-d25e-11ec-bce3-dac502259ad0.png

同樣在終端 1 中,再次啟動 vmstat 2 命令:

c36567fa-d25e-11ec-bce3-dac502259ad0.png

您可以看到此時 buff0。現(xiàn)在在終端 2 中,運行以下命令:

c37f4dc8-d25e-11ec-bce3-dac502259ad0.png

然后,回到終端 1 觀察:

c3991460-d25e-11ec-bce3-dac502259ad0.png

觀察 vmstat 的輸出,你會發(fā)現(xiàn)在讀盤的時候(也就是 bi > 0 的時候),BufferCache 都在增長,但是顯然 Buffer 的增長要快很多。這意味著當從磁盤讀取時,數(shù)據(jù)被緩存在 Buffer 中。

現(xiàn)在我們幾乎可以得出結論:

讀取文件時數(shù)據(jù)會緩存在 Cache 中,讀取磁盤時數(shù)據(jù)會緩存在 Buffer 中。

結論

在這里您應該會發(fā)現(xiàn),雖然本文對 BufferCache 進行了描述,但仍然無法涵蓋所有細節(jié)。我們如今學到了以下兩點:

  • Buffer:既可以用作“要寫入磁盤的數(shù)據(jù)緩存”,也可以用作“讀取磁盤讀的數(shù)據(jù)緩存”。
  • Cache:既可以用作“從讀取文件的頁面緩存”,也可以用作“寫入文件的頁面緩存”。

審核編輯 :李倩


聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 磁盤
    +關注

    關注

    1

    文章

    379

    瀏覽量

    25209
  • buffer
    +關注

    關注

    2

    文章

    120

    瀏覽量

    30054
  • 命令
    +關注

    關注

    5

    文章

    684

    瀏覽量

    22027

原文標題:Linux 內存中的緩沖區(qū)(Buffer)與緩存(Cache)

文章出處:【微信號:magedu-Linux,微信公眾號:馬哥Linux運維】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    什么是緩存(Cache)及其作用

    緩存(Cache)是一種高速存儲器,用于臨時存儲數(shù)據(jù),以便快速訪問。在計算機系統(tǒng)中,緩存的作用是減少處理器訪問主存儲器(如隨機存取存儲器RAM)所需的時間。 緩存(Cache)概述 緩存是一種位于
    的頭像 發(fā)表于 12-18 09:28 ?577次閱讀

    Cache和內存有什么區(qū)別

    Cache(高速緩存)和內存(Memory,通常指主存儲器或RAM)是計算機存儲系統(tǒng)中兩個重要的組成部分,它們在計算機的性能和數(shù)據(jù)處理中扮演著不同的角色。以下是對Cache和內存之間區(qū)別的詳細解析。
    的頭像 發(fā)表于 09-26 15:28 ?1563次閱讀

    MSPM0 UART通信中DMA和Ring Buffer環(huán)形緩沖的應用

    電子發(fā)燒友網站提供《MSPM0 UART通信中DMA和Ring Buffer環(huán)形緩沖的應用.pdf》資料免費下載
    發(fā)表于 09-05 11:01 ?0次下載
    MSPM0 UART通信中DMA和Ring <b class='flag-5'>Buffer</b>環(huán)形緩沖的應用

    解析Arm Neoverse N2 PMU事件L2D_CACHE_WR

    有客戶希望我們幫忙分析 Eigen gemm 基準測試的一些執(zhí)行情況。具體來說是為什么 L1D_CACHE_WR 的值會低于 L2D_CACHE_WR,這種情況令人費解。
    的頭像 發(fā)表于 09-03 11:42 ?1290次閱讀
    解析Arm Neoverse N2 PMU事件L2D_<b class='flag-5'>CACHE</b>_WR

    Cortex R52內核Cache的具體操作(2)

    本節(jié)內容主要講述CortexR52內核Cache的具體操作包括使緩存無效(invalidate)操作,清除(clean)緩存。有的時候客戶可能需要對cache做一些清理,比如invalidate
    的頭像 發(fā)表于 07-15 15:44 ?1409次閱讀
    Cortex R52內核<b class='flag-5'>Cache</b>的具體操作(2)

    Cortex R52內核Cache的相關概念(1)

    在開始閱讀本系列文章之前,請先參閱《有關CR52 MPU配置說明》。因為這篇文章講述了,cache配置所涉及到的寄存器的設置和MPU的一些基本概念。如果讀者都已經理解了上述內容,可以跳過。本章內容主要講述cache屬性的具體含意、注意事項、以及在RZ/T2M的性能測試。
    的頭像 發(fā)表于 07-15 10:37 ?1592次閱讀
    Cortex R52內核<b class='flag-5'>Cache</b>的相關概念(1)

    CortexR52內核Cache的具體操作

    本節(jié)內容主要講述CortexR52內核Cache的具體操作包括使緩存無效(invalidate)操作,清除(clean)緩存。有的時候客戶可能需要對cache做一些清理,比如invalidate
    的頭像 發(fā)表于 07-15 10:32 ?1295次閱讀
    CortexR52內核<b class='flag-5'>Cache</b>的具體操作

    OpenHarmony語言基礎類庫【@ohos.buffer (Buffer)】

    Buffer對象用于表示固定長度的字節(jié)序列,是專門存放二進制數(shù)據(jù)的緩存區(qū)。
    的頭像 發(fā)表于 04-23 17:34 ?879次閱讀
    OpenHarmony語言基礎類庫【@ohos.<b class='flag-5'>buffer</b> (<b class='flag-5'>Buffer</b>)】

    為什么HAL庫在操作Flash erase的時候,需要把I-Cache和D-Cache關閉呢?

    請問為什么HAL庫在操作Flash erase的時候,需要把I-Cache和D-Cache關閉呢? 這有什么原因呢? 有人可以解答嗎?
    發(fā)表于 04-07 09:08

    STM32F429使用外部SPI flash,只要執(zhí)行Bitmap::cache(id)就進入硬件錯誤怎么解決?

    ,就進入硬件錯誤。 執(zhí)行Bitmap::cacheAll()函數(shù)也會進入硬件錯誤。 正常執(zhí)行cache函數(shù)之后會進入TouchGFXHAL::blockCopy()函數(shù),然后執(zhí)行自定義的拷貝函數(shù),但是
    發(fā)表于 03-27 07:39

    請問STM32MP13X的MMU和Cache如何使能?

    STM32MP13X的MMU和Cache如何使能?修改了hal_conf里的DATA_CACHE_ENABLE的宏console里還是顯示沒開,在設置里的Define symbols把NO_CACHE_USE刪了好像還是不行。。
    發(fā)表于 03-12 06:46

    Cache中的data在不同核間獲取數(shù)據(jù)的時候如何保證拿到的數(shù)據(jù)是最新的?

    1. Cache 中的data在不同核間獲取數(shù)據(jù)的時候如何保證拿到的數(shù)據(jù)是最新的? 2.如果關閉了Cache ,運行速度就變好慢,但是core0取core1的數(shù)據(jù)又想要保持是最新的數(shù)據(jù)值,此時沒法打開cache ,這種情況該怎么
    發(fā)表于 01-31 06:49

    先楫HPM片上Cache使用指南經驗分享

    高速緩存(Cache)主要是為了解決CPU運算速度與內存(Memory)讀寫速度不匹配的矛盾而存在, 是CPU與存儲設備之間的臨時存貯器,容量小,但是交換速度比內存快。內置高速緩存通常對CPU的性能提升具有較大作用。
    的頭像 發(fā)表于 01-22 16:07 ?1315次閱讀
    先楫HPM片上<b class='flag-5'>Cache</b>使用指南經驗分享

    請問MINI54 SPI BUFFER怎么用?

    各位前輩,我想請問一下,MINI 54 SPI BUFFER 怎么使用?比如怎么定義,怎么引用。哪位可以告訴我一下,不勝感激。
    發(fā)表于 01-17 08:08

    時鐘Buffer芯片是什么?其作用是啥?它被用在什么地方?

    時鐘Buffer芯片是什么?其作用是啥?它被用在什么地方? 時鐘Buffer芯片是一種用于管理和增強電子設備中的時鐘信號的集成電路。時鐘信號在數(shù)字電子設備中非常重要,它用于同步各個模塊的工作,確保
    的頭像 發(fā)表于 01-16 15:10 ?4470次閱讀
    主站蜘蛛池模板: 一区二区三区www| 高清一区高清二区视频| 35qao强力打造免费上线高清| ggg成人| 国产a三级三级三级| 欧美日韩国产一区二区| 国产精品高清一区二区三区| 午夜毛片不卡高清免费| 国产小视频在线免费| 在线观看不卡一区| 永久看日本大片免费| 亚洲一区二区三区网站| 天天看影院| 久久人成| 夜夜夜爽| good韩国理论在线三级| 老师办公室高h文小说| 四虎影院欧美| 黄色一级片视频| 色综合综合色| 男人操女人视频免费| 李老汉的性生生活1全部| 免费一级大片| 午夜免费片| 欧美高清a| 拍拍拍美女黄色1000视频| 超级狂色而且免费又超好看| 久久精品美女久久| 国产精品久久久久久久人热| 巨乳色网址| 手机看片1024福利| 亚洲黄网站wwwwww| 日韩一级免费视频| 中文字幕在线观看你懂的| 51xtv成人影院| 午夜美女写真福利写视频| 国内一国产农村妇女一级毛片| 人人干人人做| 老司机午夜永久在线观看| 国产资源在线观看| h视频免费观看|