free指令會顯示內存的使用狀況,包括實體內存,虛擬的交換文件內存,共享內存區段,以及系統核心使用的緩衝區等
命 令: free 功能說明:顯示內存狀態。 語 法: free [-bkmotV][-s <間隔秒數>] 補充說明:free指令會顯示內存的使用狀況,包括實體內存,虛擬的交換文件內存,共享內存區段,以及系統核心使用的緩衝區等。 參 數: -b 以Byte爲單位顯示內存使用狀況。 -k 以KB爲單位顯示內存使用狀況。 -m 以MB爲單位顯示內存使用狀況。 -o 不顯示緩衝區調節列。 -s<間隔秒數> 持續觀察內存使用情況。 -t 顯示內存總和列。 -V 顯示版本信息。 若是內存不足,能夠增長swap交換分區. 具體方法請參考: [root@test]# mkdir -p /u01/swap [root@test]# dd if=/dev/zero of=/u01/swap/swap bs=1024 count=2048000 2048000+0 records in 2048000+0 records out [root@test]# mkswap /u01/swap/swap Setting up swapspace version 1, size = 2097147 kB [root@test]# swapon /u01/swap/swap 使用示例 [root@jb51.net ~]#free total used free shared buffers cached Mem: 515308 377176 138132 0 58024 255072 -/+ buffers/cache: 64080 451228 Swap: 1048568 0 1048568 [root@jb51.net ~]#free -m total used free shared buffers cached Mem: 503 368 134 0 56 249 -/+ buffers/cache: 62 440 Swap: 1023 0 1023 Mem:表示物理內存統計 -/+ buffers/cached:表示物理內存的緩存統計 Swap:表示硬盤上交換分區的使用狀況,這裏咱們不去關心。 系統的總物理內存:255268Kb(256M),但系統當前真正可用的內存b並非第一行free 標記的 16936Kb,它僅表明未被分配的內存。 第1行 Mem: total:表示物理內存總量。 used:表示總計分配給緩存(包含buffers 與cache )使用的數量,但其中可能部分緩存並未實際使用。 free:未被分配的內存。 shared:共享內存,通常系統不會用到,這裏也不討論。 buffers:系統分配但未被使用的buffers 數量。 cached:系統分配但未被使用的cache 數量。 buffer 與cache 的區別見後面。 total = used + free 第2行 -/+ buffers/cached: used:也就是第一行中的used - buffers-cached 也是實際使用的內存總量。 free:未被使用的buffers 與cache 和未被分配的內存之和,這就是系統當前實際可用內存。 free 2= buffers1 + cached1 + free1 //free2爲第二行、buffers1等爲第一行 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 第3行: 第三行所指的是從應用程序角度來看, 對於應用程序來講,buffers/cached 是等於可用的, 由於buffer/cached是爲了提升文件讀取的性能, 當應用程序需在用到內存的時候,buffer/cached會很快地被回收。 因此從應用程序的角度來講,可用內存=系統free memory+buffers+cached. 第二行(mem)的used/free與第三行(-/+ buffers/cache) used/free的區別。 這兩個的區別在於使用的角度來看, 第一行是從OS的角度來看,由於對於OS,buffers/cached 都是屬於被使用,因此他的可用內存是16936KB,已用內存是238332KB,其中包括,內核(OS)使用+Application(X,oracle,etc)使用的+buffers+cached. 第三行所指的是從應用程序角度來看,對於應用程序來講,buffers/cached 是等於可用的,由於buffer/cached是爲了提升文件讀取的性能,當應用程序需在用到內存的時候,buffer/cached會很快地被回收。 因此從應用程序的角度來講,可用內存=系統free memory+buffers+cached. 接下來解釋何時內存會被交換,以及按什麼方交換。 當可用內存少於額定值的時候,就會開會進行交換.如何看額定值(RHEL4.0): #cat /proc/meminfo 交換將經過三個途徑來減小系統中使用的物理頁面的個數: 1.減小緩衝與頁面cache的大小, 2.將系統V類型的內存頁面交換出去, 3.換出或者丟棄頁面。(Application 佔用的內存頁,也就是物理內存不足)。 事實上,少許地使用swap是否是影響到系統性能的。 下面是buffers與cached的區別。 buffers是指用來給塊設備作的緩衝大小,他只記錄文件系統的metadata以及 tracking in-flight pages.cached是用來給文件作緩衝。那就是說:buffers是用來存儲,目錄裏面有什麼內容,權限等等。 而cached直接用來記憶咱們打開的文件,若是你想知道他是否是真的生效,你能夠試一下,前後執行兩次命令#man X ,你就能夠明顯的感受到第二次的開打的速度快不少。 實驗:在一臺沒有什麼應用的機器上作會看得比較明顯。記得實驗只能作一次,若是想多作請換一個文件名。 #free #man X #free #man X #free 你能夠前後比較一下free後顯示buffers的大小。 另外一個實驗: #free# ls /dev #free 你比較一下兩個的大小,固然這個buffers隨時都在增長,但你有ls過的話,增長的速度會變得快,這個就是buffers/chached的區別。 由於Linux將你暫時不使用的內存做爲文件和數據緩存,以提升系統性能, 當你須要這些內存時,系統會自動釋放 (不像windows那樣,即便你有不少空閒內存,他也要訪問一下磁盤中的pagefiles) 使用free命令將used的值減去buffer和cache的值就是你當前真實內存使用 -------------- 對操做系統來說是Mem的參數.buffers/cached 都是屬於被使用, 因此它認爲free只有16936. 對應用程序來說是(-/+ 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看內存是否夠用的標準哦.