Linux作業系統中記憶體buffer和cache的區別
free 命令相對於top 提供了更簡潔的檢視系統記憶體使用情況:
$ free
total used free shared buffers cachedMem: 255268 238332 16936 0 85540 126384-/+ buffers/cache: 26408 228860Swap: 265000 0 265000
Mem:表示實體記憶體統計
-/+ buffers/cached:表示實體記憶體的快取統計
Swap:表示硬碟上分割槽的使用情況,這裡我們不去關心。
系統的總實體記憶體:255268Kb(256M),但系統當前真正可用的記憶體b並不是第一行free 標記的 16936Kb,它僅代表未被分配的記憶體。
我們使用total1、used1、free1、used2、free2 等名稱來代表上面統計資料的各值,1、2 分別代表第一行和第二行的資料。
total1:表示實體記憶體總量。
used1:表示總計分配給快取(包含buffers 與cache )使用的數量,但其中可能部分快取並未實際使用。
free1:未被分配的記憶體。
shared1:共享記憶體,一般系統不會用到,這裡也不討論。
buffers1:系統分配但未被使用的buffers 數量。
cached1:系統分配但未被使用的cache 數量。buffer 與cache 的區別見後面。
used2:實際使用的buffers 與cache 總量,也是實際使用的記憶體總量。
free2:未被使用的buffers 與cache 和未被分配的記憶體之和,這就是系統當前實際可用記憶體。
可以整理出如下等式:
total1 = used1 + free1total1 = used2 + free2used1 = buffers1 + cached1 + used2free2 = buffers1 + cached1 + free1
buffer 與cache 的區別
A buffer is something that has yet to be "written" to disk. A cache is something that has been "read" from the disk and stored for later use.
更詳細的解釋參考:Difference Between Buffer and Cache
對於共享記憶體(Shared memory),主要用於在UNIX 環境下不同程式之間共享資料,是程式間通訊的一種方法,一般的應用程式不會申請使用共享記憶體,筆者也沒有去驗證共享記憶體對上面等式的影響。如果你有興趣,請參考:What is Shared Memory?
cache 和 buffer的區別:
Cache:快取記憶體,是位於CPU與主記憶體間的一種容量較小但速度很高的器。由於CPU的速度遠高於主記憶體,CPU直接從記憶體中存取資料要等待一定時間週期,Cache中儲存著CPU剛用過或迴圈使用的一部分資料,當CPU再次使用該部分資料時可從Cache中直接呼叫,這樣就減少了CPU的等待時間,提高了系統的效率。Cache又分為一級Cache(L1 Cache)和二級Cache(L2 Cache),L1 Cache整合在CPU內部,L2 Cache早期一般是焊在主機板上,現在也都整合在CPU內部,常見的容量有256KB或512KB L2 Cache。
Buffer:緩衝區,一個用於速度不同步的裝置或優先順序不同的裝置之間傳輸資料的區域。透過緩衝區,可以使程式之間的相互等待變少,從而使從速度慢的裝置讀入資料時,速度快的裝置的操作程式不發生間斷。
Free中的buffer和cache:(它們都是佔用記憶體):
buffer : 作為buffer cache的記憶體,是塊裝置的讀寫緩衝區
cache: 作為page cache的記憶體, 檔案系統的cache
如果 cache 的值很大,說明cache住的檔案數很多。如果頻繁訪問到的檔案都能被cache住,那麼磁碟的讀IO bi會非常小。
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/9099175/viewspace-1011126/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- Linux記憶體、Swap、Cache、BufferLinux記憶體
- Linux Buffer/Cache 的區別Linux
- Cache 和 Buffer 的區別在哪裡?
- Linux作業系統記憶體淺析Linux作業系統記憶體
- buffer與cache的區別
- Cache和Buffer都是快取,有什麼區別?Linux快取Linux
- Cache 和 Buffer 有什麼區別?
- 調整緩衝區快取記憶體(Buffer Cache)的效能(轉)快取記憶體
- MySQL記憶體管理,記憶體分配器和作業系統MySql記憶體作業系統
- 作業系統-記憶體管理作業系統記憶體
- 作業系統——記憶體管理作業系統記憶體
- Unix和Linux作業系統有什麼區別Linux作業系統
- 計算機buffer和cache的區別?linux運維學習知識計算機Linux運維
- 【作業系統】記憶體管理概述作業系統記憶體
- 效能測試必備知識(11)- 怎麼理解記憶體中的Buffer和Cache?記憶體
- linux查詢作業系統資訊(CPU、記憶體、硬碟)Linux作業系統記憶體硬碟
- 作業系統-記憶體、檔案管理作業系統記憶體
- 作業系統的記憶體管理你知道嗎作業系統記憶體
- 記憶體分配策略中,堆和棧的區別記憶體
- 作業系統——記憶體管理學習筆記作業系統記憶體筆記
- linux是什麼作業系統 linux和windows的區別詳細說明Linux作業系統Windows
- 如何區分Linux和Unix?作業系統!Linux作業系統
- 計算機作業系統——虛擬記憶體與實體記憶體計算機作業系統記憶體
- Linux作業系統關於ftp,samba,nfs的區別Linux作業系統FTPSambaNFS
- java記憶體溢位和記憶體洩漏的區別Java記憶體溢位
- Unix和Linux作業系統有什麼區別?看這裡!Linux作業系統
- 作業系統(八) -- 記憶體的分段與分頁作業系統記憶體
- 華納雲:Linux作業系統的記憶體管理方法是什麼Linux作業系統記憶體
- 作業系統-執行緒和程式的區別作業系統執行緒
- 作業系統_程式和執行緒的區別作業系統執行緒
- 讀懂作業系統之虛擬記憶體TLB與快取(cache)關係篇(四)作業系統記憶體快取
- linux和windows系統的區別LinuxWindows
- 【知識分享】伺服器記憶體和普通記憶體的區別伺服器記憶體
- 在Linux中,如何檢查系統的CPU和記憶體使用情況?Linux記憶體
- kubernetes中的記憶體表示單位Mi和M的區別記憶體
- Linux記憶體子系統——Locking Pages(記憶體鎖定)Linux記憶體
- 作業系統——記憶體連續分配管理方式作業系統記憶體
- Linux和Windows作業系統之間有何區別?學哪個好?LinuxWindows作業系統
- 手動釋放Linux上的Swap、Buffer和CacheLinux