Linux內存解釋(轉)

  你們注意的是,這裏的內存指的是linux下的內存管理方式。我告訴有朋友我一直用Linux,他問我了一下我爲何linux使用的內存這麼高,他講他1G的內存free才232M,講win xp才用200M的內存 php

      其實啊,linux的內存是很說究的,以下顯示free是顯示的當前內存的使用。-m的意思是M字節來顯示內容,咱們來一塊兒看看。java

$ free -m
                   total         used       free     shared    buffers     cached
Mem:         1002          769        232          0         62        421
-/+ buffers/cache:        286        715
Swap:         1153          0           1153
node

第一部分Mem行:
total 內存總數: 1002M
used 已經使用的內存數: 769M
free 空閒的內存數: 232M
shared 當前已經廢棄不用,老是0
buffers Buffer 緩存內存數: 62M
cached Page 緩存內存數:421M
linux

關係:total(1002M) = used(769M) + free(232M)程序員

第二部分(-/+ buffers/cache):
(-buffers/cache) used內存數:286M (指的第一部分Mem行中的used - buffers - cached)
(+buffers/cache) free內存數: 715M (指的第一部分Mem行中的free + buffers + cached)
windows

可見-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看內存是否夠用的標準哦。

 

轉自:http://blog.chinaunix.net/u3/98941/showart.php?id=2093545



已有 0 人發表留言,猛擊->>這裏<<-參與討論


JavaEye推薦
相關文章
相關標籤/搜索