free命令結果分析

1.free命令

 

# free -m

             total       used       free     shared    buffers     cached
Mem:          3072       2459        612          0        207       1803
-/+ buffers/cache:        447       2624
Swap:         1913          0       1913

 

1.1 結果分析

 

行/列   C1 C2 C3 C4 C5 C6
    total used free shared buffers cached
R1 Mem 3072 2459 612 0 207 1803
R2 -/+ b/c   447 2624      
R3 Swap 1913 0 1913      

第一行(R1)含義

 

位置 名字 含義
C1R1 total 內存總數 3072MB
C2R1 used 已經使用的內存數2459MB
C3R1 free 空閒的內存數 612MB
C4R1 shared 當前已經廢棄不用,總是0 //TODO ?
C5R1 buffers Buffer Cache內存數 207
C6R1 cached Page Cache內存數 1803

由此可見,有:total = used + free

第二行(R2)含義(即 -/+ buffers/cache的意思):

 

位置 名字 含義
C1R2 -b/c -b/c的內存數447(C2R1-C5R1-C6R1=used-b-c)
C2R2 +b/c +b/c的內存數2624(C3R1+C5R1+C6R1=free+b+c)


可見-buffers/cache反映的是被程序實實在在吃掉的內存,而+buffers/cache反映的是可以挪用的內存總數。

第三行(R3)單獨針對交換分區。

 

2.概念簡介

爲了提高磁盤存取效率, Linux做了一些精心的設計, 除了對dentry進行緩存(用於VFS,加速文件路徑名到inode的轉換), 還採取了兩種主要Cache方式:Buffer Cache和Page Cache。前者針對磁盤塊的讀寫,後者針對文件inode的讀寫。這些Cache有效縮短了 I/O系統調用(如read,write,getdents)的時間。

2.1 第一行R1(Mem)的used/free與第二行R2(-/+ buffers/cache) used/free的區別:

這兩個的區別在於使用的角度.

第一行R1是從OS的角度來看,因爲對於OS,buffers/cached 都是屬於被使用,所以他的可用內存是612MB,已用內存是2059MB,其中包括,內核(OS)使用+Application(X, oracle,etc)使用的+buffers+cached.

第二行R2所指的是從應用程序角度來看,對於應用程序來說,buffers/cached 是可用的,因爲buffer/cached是爲了提高文件讀取的性能而設,當應用程序要用到內存的時候,buffer/cached會很快地被回收。所以從應用程序的角度來說,可用內存=系統free memory+buffers+cached.

如上例:
2624= 612+207+1803

2.2 buffers與cached的區別:

buffers是用來給塊設備做的緩衝大小,他只記錄文件系統的metadata以及 tracking in-flight pages。

cached用來給文件做緩衝。

所以,buffers是用來存儲目錄裏面有什麼內容,權限等等,而cached用來記憶我們打開的文件.

2.2.1 實驗

如果你想知道他是不是真的生效,你可以試一下,先後執行兩次命令#man kill ,你就可以明顯的感覺到第二次的開打的速度快很多。

實驗1:

在一臺沒有什麼應用的機器上做會看得比較明顯。記得實驗只能做一次,如果想多做請換一個文件名。

 

#free
#man kill
#free
#man kill
#free

比較一下free先後顯示的buffers的大小。

實驗2:

 

#free
#ls /dev
#free

 

比較一下兩個的大小,當然這個buffers隨時都在增加,但有ls過的話,增加的速度會變得快,這個就是buffers/chached的區別。

因爲Linux會將暫時不使用的內存作爲文件和數據緩存,以提高系統性能,當應用程序需要這些內存時,系統會自動釋放(不像windows那樣,即使你有很多空閒內存,他也要訪問一下磁盤中的pagefiles)  

2.3 內存交換條件及方式:

當可用內存少於額定值的時候,就會開始進行交換.
如何看額定值

 

#cat /proc/meminfo

交換將通過三個途徑來減少系統中使用的物理頁面的個數:
1.減少緩衝與頁面cache的大小;
2.將系統V類型的內存頁面交換出支;
3.換出或者丟棄頁面。(Application 佔用的內存頁,也就是物理內存不足)。
事實上,少量地使用swap是不會影響到系統性能的。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章