2009年12月19日 星期六

Linux作業系統中記憶體buffer和cache的區別

Free

  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:表示硬盤上交換分區的使用情況。
 
  系統的總物理記憶體:255268Kb256M),但系統當前真正可用的記憶體b並不是第一行free 標記的 16936Kb,它僅代表未被分配的記憶體。
 
  我們使用total1used1free1used2free2 等名稱來代表上面統計數據的各值,12 分別代表第一行和第二行的數據。
 
  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 + used 2f ree2 = 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)L 1 C ache集成在CPU內部,L 2 C ache早期一般是焊在主板上,現在也都集成在CPU內部,常見的容量有256KB512KB L2 Cache
 
  Buffer:緩衝區,一個用於存儲速度不同步的設備或優先級不同的設備之間傳輸數據的區域。通過緩衝區,可以使進程之間的相互等待變少,從而使從速度慢的設備讀入數據時,速度快的設備的操作進程不發生間斷。
 
  Free中的buffercache:(它們都是佔用記憶體):
 
  buffer : 作為buffer cache的記憶體,是塊設備的讀寫緩衝區
 
  cache: 作為page cache的記憶體, 文件系統的cache
 
  如果 cache 的值很大,說明cache住的文件數很多。如果頻繁訪問到的文件都能被cache住,那麼磁片的讀IO bi會非常小。