Linux 內存used free swap buffer cache使用說明

. 內存使用說明linux

 

Free 命令相對於top 提供了更簡潔的查看系統內存使用狀況:緩存

 

[root@rac1 ~]# free spa

             total       used       free     shared    buffers     cached.net

Mem:       1035108   1008984      26124      0     124212     413000blog

-/+ buffers/cache:        471772      563336進程

Swap:       2096472   842320     1254152內存

 

這裏顯示的單位是KBget

 

       在linux的內存分配機制中,優先使用物理內存,當物理內存還有空閒時(還夠用),不會釋放其佔用內存,就算佔用內存的程序已經被關閉了,該程序所佔用的內存用來作緩存使用,對於開啓過的程序、或是讀取剛存取過得數據會比較快。有關Linux內存機制參考:同步

       Linux 內存機制it

       http://blog.csdn.net/tianlesoftware/archive/2010/04/08/5463790.aspx

 

Mem:表示物理內存統計。
-/+ buffers/cached:表示物理內存的緩存統計
Swap:表示硬盤上交換分區的使用狀況。只有mem被當前進程實際佔用完,即沒有了buffers和cache時,纔會使用到swap。

 

Mem 行(第一行)數聽說明:

       Total:1035108KB。表示物理內存總大小。

       Used:1008984KB。表示總計分配給緩存(包含buffers 與cache )使用的數量,但其中可能部分緩存並未實際使用。

       Free:26124KB。表示未被分配的內存。

       Shared:0kb。共享內存,通常系統不會用到。

       Buffers:124212KB。系統分配但未被使用的buffers 數量。

       Cached:413000KB。系統分配但未被使用的cache 數量。

 

-/+ buffers/cache 行(第二行)數聽說明:

       Used:471772kb,實際使用的buffers 與cache 總量,也是實際使用的內存總量。

       Free: 563336kb, 未被使用的buffers 與cache 和未被分配的內存之和,這就是系統當前實際可用內存。

 

根據以上分析,能夠得出一下結論:

1.  實際可用內存大小:

       Free(-/+ buffers/cache行)= Free(Mem)+buffers(Mem)+Cached(Mem);

                                   563336 = 26124 + 124212+ 413000

 

2.  已經分配的內存大小:

       Used(Mem) = Used(-/+ buffers/cache)+ buffers(Mem) + Cached(Mem)

              1008984kb = 471772 + 124212 +413000

 

3.  物理內存總大小

       total(Mem) = used(-/+ buffers/cache) + free(-/+ buffers/cache)

                     1035108 = 471772 + 563336

 

 

.  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.

 

2.1 Cache

       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。
 

2.2 Buffer

       Buffer:緩衝區,一個用於存儲速度不一樣步的設備或優先級不一樣的設備之間傳輸數據的區域。經過緩衝區,能夠使進程之間的相互等待變少,從而使從速度慢的設備讀入數據時,速度快的設備的操做進程不發生間斷。

 

Free命令中顯示的buffercache,它們都是佔用內存:

       buffer : 做爲buffer cache的內存,是塊設備的讀寫緩衝區,更靠近存儲設備,或者直接就是disk的緩衝區。

       cache: 做爲page cache的內存, 文件系統的cache,是memory的緩衝區

 

       若是 cache 的值很大,說明cache住的文件數不少。若是頻繁訪問到的文件都能被cache住,那麼磁盤的讀IO 必會很是小。

       內容來源於http://blog.csdn.net/tianlesoftware/article/details/6459044

相關文章
相關標籤/搜索