linux/ubuntu下free查看記憶體佔用大的解釋 大家看看我的記憶體佔用情況:$ free -mtotal used free shared buffers cachedMem: 1908 1844 64 0 56 689-/+ buffers/cache: 1098 810Swap: 3904 0 3904 www.2cto.com 一開始嚇了我一跳,我開了個虛擬機器分了512m記憶體,別的沒開啥大程式,怎麼那個free就變成64m那麼一點兒了。。。後來查了下資料,才知道是這麼回事!如下:總實體記憶體:1908m,已用了1844m, shard:多個進程共用的記憶體為0,磁碟緩衝的大小為689MB第二行(mem)的 used/free與第三行(-/ buffers/cache) used/free的區別。 這兩個的區別在於使用的角度來看,第二行 是從OS的角度來看,因為對於 OS,buffers/cached 都是屬於被使用,所以他的可用記憶體是15864KB,已用記憶體是465932KB,其中包括,核心(OS)使用 Application(X, oracle,etc)使用的 buffers cached.第三行所指的是從應用程式角度來看,對於應用程式來 說,buffers/cached 是等於可用的,因為buffer/cached是為了提高檔案讀取的效能,當應用程式需在用到記憶體的時候,buffer/cached會很快地被回收。 www.2cto.com 所 以從應用程式的角度來說,可用記憶體=系統free memory buffers cached.Mem:表示實體記憶體統計-/+ buffers/cached:表示實體記憶體的緩衝統計Swap:表示硬碟上交換分區的使用方式,這裡我們不去關心。系統的總實體記憶體:255268Kb(256M),但系統當前真正可用的記憶體b並不是第一行free 標記的 16936Kb,它僅代表未被分配的記憶體。我們使用total1、used1、free1、used2、free2 等名稱來代表上面統計資料的各值,1、2 分別代表第一行和第二行的資料。 total1: 表示實體記憶體總量。used1: 表示總計分配給緩衝(包含buffers 與cache )使用的數量,但其中可能部分緩衝並未實際使用。free1: 未被分配的記憶體。 shared1: 共用記憶體,一般系統不會用到,這裡也不討論。buffers1: 系統分配但未被使用的buffers 數量。cached1: 系統分配但未被使用的cache 數量。buffer 與cache 的區別見後面。used2: 實際使用的buffers 與cache 總量,也是實際使用的記憶體總量。free2: 未被使用的buffers 與cache 和未被分配的記憶體之和,這就是系統當前實際可用記憶體。 可以整理出如下等式:total1 = used1 + free1 total1 = used2 + free2used1 = buffers1 + cached1 + used2free2 = buffers1 + cached1 + free1 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的區別 緩衝(cached)是把讀取過的資料儲存起來,重新讀取時若命中(找到需要的資料)就不要去讀硬碟了,若沒有命中就讀硬碟。其中的資料會根據讀取頻率進 行組織,把最頻繁讀取的內容放在最容易找到的位置,把不再讀的內容不斷往後排,直至從中刪除。 緩衝(buffers)是根據磁碟的讀寫設計的,把分散的寫操作集中進行,減少磁碟片段和硬碟的反覆尋道,從而提高系統效能。 linux有一個守護進程定 期清空緩衝內容(即寫如磁碟),也可以通過sync命令手動清空緩衝。舉個例子吧:我這裡有一個ext2的隨身碟,我往裡面cp一個3M的MP3,但隨身碟的 燈沒有跳動,過了一會兒(或者手動輸入sync)隨身碟的燈就跳動起來了。卸載裝置時會清空緩衝,所以有些時候卸載一個裝置時要等上幾秒鐘。修改/etc /sysctl.conf中的vm.swappiness右邊的數字可以在下次開機時調節swap使用原則。該數字範圍是0~100,數字越 大越傾向於使用swap。預設為60,可以改一下試試。兩者都是RAM中的資料。簡單來說,buffer是即將要被寫入磁碟的,而cache是被從磁碟中讀出來的。buffer是由各種進程分配的,被用在如輸入隊列等方面,一個簡單的例子如某個進程要求有多個欄位讀入,在所有欄位被讀入完整之前,進程把先前讀入的字 段放在buffer中儲存。cache經常被用在磁碟的I/O請求上,如果有多個進程都要訪問某個檔案,於是該檔案便被做成cache以方便下次被訪問,這樣可提供系統效能。因此,linux 記憶體 used的記憶體大是正常的, 不同於windows哦。