free 命令相對於top 提供了更簡潔的查看系統內存使用狀況:
$ free total Mem: -/+ buffers/cache: 26408 Swap:
Mem:表示物理內存統計
-/+ buffers/cached:表示物理內存的緩存統計 Swap:表示硬盤上交換分區的使用狀況,這裏咱們不去關心。 系統的總物理內存:255268Kb(256M),但系統當前真正可用的內存b並非第一行free 標記的 16936Kb,它僅表明未被分配的內存。 咱們使用total一、used一、free一、used二、free2 等名稱來表明上面統計數據的各值,一、2 分別表明第一行和第二行的數據。
total1:
used1: free1: shared1: buffers1: 系統分配但未被使用的buffers 數量。 cached1:
used2:
free2:
能夠整理出以下等式:
total1 = used1 + free1 total1 = used2 + free2 used1 free2
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會很是小。
Buffer和Cache的區別
修改/etc/sysctl.conf中的vm.swappiness右邊的數字能夠在下次開機時調節swap使用策略。該數字範圍是0~100,數字越大越傾向於使用swap。默認爲60,能夠改一下試試。
二者都是RAM中的數據。簡單來講,buffer是即將要被寫入磁盤的,而cache是被從磁盤中讀出來的。 buffer是由各類進程分配的,被用在如輸入隊列等方面,一個簡單的例子如某個進程要求有多個字段讀入,在全部字段被讀入完整以前,進程把先前讀入的字段放在buffer中保存。 cache常常被用在磁盤的I/O請求上,若是有多個進程都要訪問某個文件,因而該文件便被作成cache以方便下次被訪問,這樣可提供系統性能。
Linux的內存管理,實際上跟windows的內存管理有很相像的地方,都是用虛擬內存這個的概念,說到這裏不得不罵MS,爲何在不少時候還有很大的物理內存的時候,卻仍是用到了pagefile. 因此才常常要跟一幫人吵着說Pagefile的大小,以及如何分配這個問題,在Linux你們就不用再吵什麼swap大小的問題,我我的認爲,swap設個512M已經足夠了,若是你問說512M的SWAP不夠用怎麼辦?只能說大哥你仍是加內存吧,要不就檢查你的應用,是否是真的出現了memory leak.
在Linux下查看內存咱們通常用command free
[root@nonamelinux ~]# free Mem: Swap: 下面是對這些數值的解釋: 第二行(mem): total:總計物理內存的大小。 used:已使用多大。 free:可用有多少。 Shared:多個進程共享的內存總額。 Buffers/cached:磁盤緩存的大小。 第三行(-/+ buffers/cached): used:已使用多大。 free:可用有多少。 第四行就很少解釋了。 區別: 第二行(mem)的used/free與第三行(-/+ buffers/cache) used/free的區別。 這兩個的區別在於使用的角度來看,第一行是從OS的角度來看,由於對於OS,buffers/cached 都是屬於被使用,因此他的可用內存是8908KB,已用內存是377116KB,其中包括,內核(OS)使用+Application(X,oracle,etc)使用的+buffers+cached. 第三行所指的是從應用程序角度來看,對於應用程序來講,buffers/cached 是等於可用的,由於buffer/cached是爲了提升文件讀取的性能,當應用程序需在用到內存的時候,buffer/cached會很快地被回收。 因此從應用程序的角度來講,可用內存=系統free( memory+buffers+cached.) 如上例: 185656=8908+21280+155468接下來解釋何時內存會被交換,以及按什麼方交換。當可用內存少於額定值的時候,就會開會進行交換.如何看額定值(RHEL4.0):#cat /proc/meminfo交換將經過三個途徑來減小系統中使用的物理頁面的個數: 1.減小緩衝與頁面cache的大小,2.將系統V類型的內存頁面交換出去, 3.換出或者丟棄頁面。(Application 佔用的內存頁,也就是物理內存不足)。事實上,少許地使用swap是否是影響到系統性能的。 |