詳解Linux內存使用信息

命令:free -m(-m的意思是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/cache)的結果中有關used和free爲什麼這麼奇怪.
其實我們可以從二個方面來解釋.
對操作系統來講是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)的時間。

記住內存是拿來用的,不是拿來看的.不象windows, 無論你的真實物理內存有多少,他都要拿硬盤交換文件來讀.這也就是windows爲什麼常常提示虛擬空間不足的原因.你們想想,
多無聊,在內存還有大部分 的時候,拿出一部分硬盤空間來充當內存.硬盤怎麼會快過內存.所以我們看linux,只要不用swap的交換空間,就不用擔心自己的內存太少.如果常常
swap用很多,可能你就要考慮加物理內存了.這也是linux看內存是否夠用的標準哦.

另外使用top命令可以動態查看內存、CPU以及佔用資源最多的進程列表。
發佈了97 篇原創文章 · 獲贊 60 · 訪問量 37萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章