檢視linux可用記憶體

lansesl2008發表於2013-12-27
$ free -m
             total       used       free     shared    buffers     cached
Mem:         1002        769        232          0         62        421
-/+ buffers/cache:        286        715
Swap:         1153          0       1153


第一部分Mem行:
total 記憶體總數: 1002M
used 已經使用的記憶體數: 769M
free 空閒的記憶體數: 232M
shared 當前已經廢棄不用,總是0
buffers Buffer 快取記憶體數: 62M
cached Page 快取記憶體數:421M
關係:total(1002M) = used(769M) + free(232M)
第二部分(-/+ buffers/cache):
(-buffers/cache) used記憶體數:286M (指的第一部分Mem行中的used - buffers - cached)
(+buffers/cache) free記憶體數: 715M (指的第一部分Mem行中的free + buffers + cached)
可見-buffers/cache反映的是被程式實實在在吃掉的記憶體,而+buffers/cache反映的是可以挪用的記憶體總數
第三部分是指交換分割槽, 我想不講大家都明白.
其實我們可以從二個方面來解釋.
對作業系統來講是Mem的引數.buffers/cached 都是屬於被使用,所以它認為free只有232.
應用程式來講是(-/+ buffers/cach).buffers/cached 是等同可用的,因為buffer/cached是為了提高程式執行的效能
當程式使用記憶體時,buffer/cached會很快地被使用。所以,以應用來看看,以(-/+ buffers/cache)的free和used為主.
所以我們看這個就好了.另外告訴大家一些常識.Linux為了提高磁碟和記憶體存取效率, Linux做了很多精心的設計, 除了對
dentry進行快取(用於VFS,加速檔案路 徑名到inode的轉換), 還採取了兩種主要Cache方式:Buffer Cache和Page Cache。
前者針對磁碟塊的讀寫,後者針對檔案inode的讀寫。這些Cache能有效縮短了 I/O系統呼叫(比如read,write,getdents)的時間。

源地址:http://zhidao.baidu.com/question/326456500987050125.html

相關文章