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

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

Buffer和Cache介紹

馬哥Linux運維 ? 來源:馬哥Linux運維 ? 作者:馬哥Linux運維 ? 2022-08-18 09:50 ? 次閱讀

通過free命令看Linux內(nèi)存

4ce0acec-1e31-11ed-ba43-dac502259ad0.png

total:總內(nèi)存大小。

used:已經(jīng)使用的內(nèi)存大?。ㄟ@里面包含cached和buffers和shared部分)。

free:空閑的內(nèi)存大小。

shared:進(jìn)程間共享內(nèi)存(一般不會用,可以忽略)。

buffers:內(nèi)存中寫完的東西緩存起來,這樣快速響應(yīng)請求,后面數(shù)據(jù)再定期刷到磁盤上。

cached:內(nèi)存中讀完緩存起來內(nèi)容占的大?。ㄟ@部分是為了下次查詢時快速返回)。

-/+ buffers/cache看做兩部分

-buffers/cache:正在使用的內(nèi)存大?。ㄗ⒁獠皇莡sed部分,因為buffers和cached并不是正在使用的,組織和人民需要是它們是可以釋放的),其值=used-buffers-cached。

``+buffers/cache`:可用的內(nèi)存大小(同理也不是free表示的部分),其值=free+buffers+cached。

Swap:硬盤上交換分區(qū)的使用大小。

設(shè)計的目的就是當(dāng)上面提到的+buffers/cache表示的可用內(nèi)存都已使用完,新的讀寫請求過來后,會把內(nèi)存中的部分?jǐn)?shù)據(jù)寫入磁盤,從而把磁盤的部分空間當(dāng)做虛擬內(nèi)存來使用。

Buffer和Cache介紹

4cf33740-1e31-11ed-ba43-dac502259ad0.png

Cache(緩存),為了調(diào)高CPU和內(nèi)存之間數(shù)據(jù)交換而設(shè)計,Buffer(緩沖)為了提高內(nèi)存和硬盤(或其他I/O設(shè)備的數(shù)據(jù)交換而設(shè)計)。

Cache主要是針對讀操作設(shè)計的,不過Cache概念可能容易混淆,我理解為CPU本身就有Cache,包括一級緩存、二級緩存、三級緩存,我們知道CPU所有的指令操作對接的都是內(nèi)存,而CPU的處理能力遠(yuǎn)高于內(nèi)存速度,所以為了不讓CPU資源閑置,Intel公司在CPU內(nèi)部集成了一些Cache,但畢竟不能放太多電路在里面,所以這部分Cache并不是很大,主要是用來存放一些常用的指令和常用數(shù)據(jù),真正大部分Cache的數(shù)據(jù)應(yīng)該是占用內(nèi)存的空間來緩存請求過的數(shù)據(jù),即上面的Cached部分(這部分純屬個人理解,正確與否有待考證)。

Buffer主要是針對寫操作設(shè)計的,更細(xì)的說是針對內(nèi)存和硬盤之間的寫操作來設(shè)計的,目的是將寫的操作集中起來進(jìn)行,減少磁盤碎片和硬盤反復(fù)尋址過程,提高性能。

在Linux系統(tǒng)內(nèi)部有一個守護(hù)進(jìn)程會定期清空Buffer中的內(nèi)容,將其寫入硬盤內(nèi),當(dāng)手動執(zhí)行sync命令時也會觸發(fā)上述操作。

常見癥狀

癥狀一:在Linux中頻繁存取文件,物理內(nèi)存很快用光,而cached一直在增長。

解釋:Linux會對每次請求過的數(shù)據(jù)緩存在cache里,好處就是CPU的處理速度遠(yuǎn)遠(yuǎn)高于內(nèi)存,所以在CPU和內(nèi)存通訊的時候可以快速從cache中命中結(jié)果返回。

癥狀二:Swap被占用。

解釋:內(nèi)存可能不夠了,才會占Swap,所以Swap可以作為服務(wù)器監(jiān)控的一項指標(biāo),引起注意。

手動清理Swap和buffers/cache

清理Swap

swapoff-a&&swapon-a

操作說明:如果已經(jīng)使用了Swap,且當(dāng)前清空下+buffers/cache還有空間,在執(zhí)行 swapoff -a操作時,會觸發(fā)把Swap中的內(nèi)容交換到內(nèi)存中,數(shù)據(jù)不會丟失。

清理buffers/cache:

sync;sync;sync;&&echo3>/proc/sys/vm/drop_caches

sleep2

echo0>/proc/sys/vm/drop_caches

操作說明:

sync-->將緩存的內(nèi)從寫回到硬盤中;

echo 3 >/proc/sys/vm/drop_caches-->修改drop_caches的值為3,默認(rèn)為0,改為3系統(tǒng)會清理緩存的內(nèi)容;

sleep 2 --> 等一下,防止上一步?jīng)]執(zhí)行完;

echo 0 >/proc/sys/vm/drop_caches --> 改回默認(rèn)值

總結(jié)

通過上面的分析可以知道,當(dāng)空閑物理內(nèi)存不多時,不一定表示系統(tǒng)運行狀態(tài)很差,因為內(nèi)存的cache及buffer部分可以隨時被重用,在某種意義上,這兩部分內(nèi)存也可以看作是額外的空閑內(nèi)存。

swap如果被頻繁調(diào)用,bi,bo長時間不為0,則才是內(nèi)存資源是否緊張的依據(jù)。通過free看資源時,實際主要關(guān)注-/+ buffers/cache的值就可以知道內(nèi)存到底夠不夠了。

審核編輯:彭靜
聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 緩存
    +關(guān)注

    關(guān)注

    1

    文章

    223

    瀏覽量

    26580
  • Cache
    +關(guān)注

    關(guān)注

    0

    文章

    128

    瀏覽量

    28190
  • buffer
    +關(guān)注

    關(guān)注

    2

    文章

    120

    瀏覽量

    29914

原文標(biāo)題:誰再說搞不懂 Linux 的內(nèi)存、Swap、Cache、Buffer,就把這個給他扔過去!

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

收藏 人收藏

    評論

    相關(guān)推薦

    Cache和Write Buffer一般性介紹

    Cache是位于CPU與主存儲器即DRAM(Dynamic RAM,動態(tài)存儲器)之間的少量超高速靜態(tài)存儲器SRAM(Static RAM)
    的頭像 發(fā)表于 10-31 15:07 ?536次閱讀
    <b class='flag-5'>Cache</b>和Write <b class='flag-5'>Buffer</b>一般性<b class='flag-5'>介紹</b>

    6678中CACHE的空間使用問題

    參與運算操作時會發(fā)生cache存儲空間的使用沖突么? 2、memset(void *buffer, int value, int count),對buffer起作用的是它cache中的
    發(fā)表于 06-21 13:28

    Cache機制的原理是什么?

    的高速度。CPU與外設(shè)交換數(shù)據(jù)時經(jīng)常用到buffer(緩沖),這與緩存極其相似,只不過Cache是為了提高CPU和內(nèi)存之間的數(shù)據(jù)交換速度而設(shè)計,而buffer是為了提高內(nèi)存和硬盤(或其他I/O設(shè)備)之間的數(shù)據(jù)交換速度而設(shè)計的。
    發(fā)表于 10-12 06:01

    詳談嵌入式編程需注意的Cache機制和原理

    盡可能發(fā)揮CPU的高速度。CPU與外設(shè)交換數(shù)據(jù)時經(jīng)常用到buffer(緩沖),這與緩存極其相似,只不過Cache是為了提高CPU和內(nèi)存之間的數(shù)據(jù)交換速度而設(shè)計,而buffer是為了提高內(nèi)存和硬盤(或其他I/O設(shè)備)之間的數(shù)據(jù)交換
    發(fā)表于 11-01 16:16 ?0次下載
    詳談嵌入式編程需注意的<b class='flag-5'>Cache</b>機制和原理

    BufferCache之間區(qū)別是什么?

    cpu在執(zhí)行程序所用的指令和讀數(shù)據(jù)都是針對內(nèi)存的,也就是從內(nèi)存中取得的。由于內(nèi)存讀寫速度慢,為了提高cpu和內(nèi)存之間數(shù)據(jù)交換的速度,在cpu和內(nèi)存之間增加了cache,它的速度比內(nèi)存快,但是造價
    的頭像 發(fā)表于 04-02 10:35 ?6665次閱讀

    寄存器和cache的區(qū)別介紹

    本文開始闡述了CACHE的概念、CACHE替換機構(gòu)與讀寫操作,其次介紹了寄存器的原理以及它的主要技術(shù),最后闡述了寄存器和cache兩者之間的區(qū)別。
    發(fā)表于 04-11 14:10 ?1.3w次閱讀

    Ring buffer介紹

    Buffer 比鏈表要快,因為它是數(shù)組,而且有一個容易預(yù)測的訪問模式。這很不錯,對 CPU 高速緩存友好 (CPU-cache-friendly)-數(shù)據(jù)可以在硬件層面預(yù)加載到高速緩存,因此 CPU
    發(fā)表于 04-02 14:32 ?3136次閱讀

    Linux 內(nèi)核的文件 Cache 管理機制介紹

    文件 Cache 管理是 Linux 內(nèi)核中一個很重要并且較難理解的組成部分。本文詳細(xì)介紹了 Linux 內(nèi)核中文件 Cache 管理的各個方面,希望能夠?qū)﹂_發(fā)者理解相關(guān)代碼有所幫助
    發(fā)表于 04-02 14:38 ?406次閱讀

    Linux內(nèi)核Page CacheBuffer Cache兩類緩存的作用及關(guān)系如何

    page)即為頁緩存(page cache)。塊緩存(buffer cache),則是內(nèi)核為了加速對底層存儲介質(zhì)的訪問速度,而構(gòu)建的一層緩存。
    的頭像 發(fā)表于 07-02 14:25 ?2575次閱讀
    Linux內(nèi)核Page <b class='flag-5'>Cache</b>和<b class='flag-5'>Buffer</b> <b class='flag-5'>Cache</b>兩類緩存的作用及關(guān)系如何

    MySQL緩沖區(qū)設(shè)計介紹

    1. Buffercache 的區(qū)別? Bbuffer 與 Cache 非常類似,因為它們都用于存儲數(shù)據(jù)數(shù)據(jù),被應(yīng)用層讀取字節(jié)數(shù)據(jù)。在很多場合它們有著相同的概念,但是特定場合也有一定的區(qū)別[1
    的頭像 發(fā)表于 10-15 09:50 ?1293次閱讀

    BufferCache的定義

    但是讓我問你,由于 Buffer 只是將寫入磁盤的數(shù)據(jù)的緩存。反過來,它還會緩存從磁盤讀取的數(shù)據(jù)嗎?或者 Cache 是從文件中讀取數(shù)據(jù)的緩存,那么它是否也為寫入文件緩存數(shù)據(jù)呢?
    的頭像 發(fā)表于 05-13 09:53 ?1819次閱讀

    Buffercache的區(qū)別

    Bbuffer 與 Cache 非常類似,因為它們都用于存儲數(shù)據(jù)數(shù)據(jù),被應(yīng)用層讀取字節(jié)數(shù)據(jù)。
    的頭像 發(fā)表于 07-01 10:44 ?3537次閱讀

    什么是 Cache? Cache讀寫原理

    由于寫入數(shù)據(jù)和讀取指令分別通過 D-Cache 和 I-Cache,所以需要同步 D-Cache 和 I-Cache,即復(fù)制后需要先將 D-Cach
    發(fā)表于 12-06 09:55 ?1935次閱讀

    Cache驗證參考模型對比來談復(fù)雜度權(quán)衡

    總體而言,在驗證L1 cache system (L1SYS)的過程中,L1SYS的機構(gòu)被拆分為多個模塊,包括shadow command buffer, store buffer, sram
    的頭像 發(fā)表于 04-28 09:25 ?1078次閱讀
    從<b class='flag-5'>Cache</b>驗證參考模型對比來談復(fù)雜度權(quán)衡

    buffercache的區(qū)別

    buffercache的區(qū)別 緩沖區(qū)(Buffer)和緩存(Cache)是計算機系統(tǒng)中用于提高數(shù)據(jù)讀寫效率的兩個關(guān)鍵概念,它們雖然功能有所重疊,但在實際應(yīng)用中存在一些差異。在下文中,
    的頭像 發(fā)表于 12-07 11:00 ?687次閱讀