linux free命令參數(shù)及用法詳解(linux查看內(nèi)存命令)
發(fā)布時間:2012-07-21 10:49:56 作者:佚名
我要評論

free指令會顯示內(nèi)存的使用情況,包括實體內(nèi)存,虛擬的交換文件內(nèi)存,共享內(nèi)存區(qū)段,以及系統(tǒng)核心使用的緩沖區(qū)等
命 令: free
功能說明:顯示內(nèi)存狀態(tài)。
語 法: free [-bkmotV][-s <間隔秒數(shù)>]
補充說明:free指令會顯示內(nèi)存的使用情況,包括實體內(nèi)存,虛擬的交換文件內(nèi)存,共享內(nèi)存區(qū)段,以及系統(tǒng)核心使用的緩沖區(qū)等。
參 數(shù):
-b 以Byte為單位顯示內(nèi)存使用情況。
-k 以KB為單位顯示內(nèi)存使用情況。
-m 以MB為單位顯示內(nèi)存使用情況。
-o 不顯示緩沖區(qū)調(diào)節(jié)列。
-s<間隔秒數(shù)> 持續(xù)觀察內(nèi)存使用狀況。
-t 顯示內(nèi)存總和列。
-V 顯示版本信息。
如果內(nèi)存不足,可以增加swap交換分區(qū). 具體方法請參考:
[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:表示物理內(nèi)存統(tǒng)計
-/+ buffers/cached:表示物理內(nèi)存的緩存統(tǒng)計
Swap:表示硬盤上交換分區(qū)的使用情況,這里我們不去關(guān)心。
系統(tǒng)的總物理內(nèi)存:255268Kb(256M),但系統(tǒng)當前真正可用的內(nèi)存b并不是第一行free 標記的 16936Kb,它僅代表未被分配的內(nèi)存。
第1行 Mem:
total:表示物理內(nèi)存總量。
used:表示總計分配給緩存(包含buffers 與cache )使用的數(shù)量,但其中可能部分緩存并未實際使用。
free:未被分配的內(nèi)存。
shared:共享內(nèi)存,一般系統(tǒng)不會用到,這里也不討論。
buffers:系統(tǒng)分配但未被使用的buffers 數(shù)量。
cached:系統(tǒng)分配但未被使用的cache 數(shù)量。
buffer 與cache 的區(qū)別見后面。
total = used + free
第2行 -/+ buffers/cached:
used:也就是第一行中的used - buffers-cached 也是實際使用的內(nèi)存總量。
free:未被使用的buffers 與cache 和未被分配的內(nèi)存之和,這就是系統(tǒng)當前實際可用內(nèi)存。
free 2= buffers1 + cached1 + free1 //free2為第二行、buffers1等為第一行
buffer 與cache 的區(qū)別:
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行:
第三行所指的是從應(yīng)用程序角度來看,
對于應(yīng)用程序來說,buffers/cached 是等于可用的,
因為buffer/cached是為了提高文件讀取的性能,
當應(yīng)用程序需在用到內(nèi)存的時候,buffer/cached會很快地被回收。
所以從應(yīng)用程序的角度來說,可用內(nèi)存=系統(tǒng)free memory+buffers+cached.
第二行(mem)的used/free與第三行(-/+ buffers/cache) used/free的區(qū)別。
這兩個的區(qū)別在于使用的角度來看,
第一行是從OS的角度來看,因為對于OS,buffers/cached 都是屬于被使用,所以他的可用內(nèi)存是16936KB,已用內(nèi)存是238332KB,其中包括,內(nèi)核(OS)使用+Application(X,oracle,etc)使用的+buffers+cached.
第三行所指的是從應(yīng)用程序角度來看,對于應(yīng)用程序來說,buffers/cached 是等于可用的,因為buffer/cached是為了提高文件讀取的性能,當應(yīng)用程序需在用到內(nèi)存的時候,buffer/cached會很快地被回收。
所以從應(yīng)用程序的角度來說,可用內(nèi)存=系統(tǒng)free memory+buffers+cached.
接下來解釋什么時候內(nèi)存會被交換,以及按什么方交換。
當可用內(nèi)存少于額定值的時候,就會開會進行交換.如何看額定值(RHEL4.0):
#cat /proc/meminfo
交換將通過三個途徑來減少系統(tǒng)中使用的物理頁面的個數(shù):
1.減少緩沖與頁面cache的大小,
2.將系統(tǒng)V類型的內(nèi)存頁面交換出去,
3.換出或者丟棄頁面。(Application 占用的內(nèi)存頁,也就是物理內(nèi)存不足)。
事實上,少量地使用swap是不是影響到系統(tǒng)性能的。
下面是buffers與cached的區(qū)別。
buffers是指用來給塊設(shè)備做的緩沖大小,他只記錄文件系統(tǒng)的metadata以及 tracking in-flight pages.cached是用來給文件做緩沖。那就是說:buffers是用來存儲,目錄里面有什么內(nèi)容,權(quán)限等等。
而cached直接用來記憶我們打開的文件,如果你想知道他是不是真的生效,你可以試一下,先后執(zhí)行兩次命令#man X ,你就可以明顯的感覺到第二次的開打的速度快很多。
實驗:在一臺沒有什么應(yīng)用的機器上做會看得比較明顯。記得實驗只能做一次,如果想多做請換一個文件名。
#free
#man X
#free
#man X
#free
你可以先后比較一下free后顯示buffers的大小。
另一個實驗:
#free#
ls /dev
#free
你比較一下兩個的大小,當然這個buffers隨時都在增加,但你有l(wèi)s過的話,增加的速度會變得快,這個就是buffers/chached的區(qū)別。
因為Linux將你暫時不使用的內(nèi)存作為文件和數(shù)據(jù)緩存,以提高系統(tǒng)性能,
當你需要這些內(nèi)存時,系統(tǒng)會自動釋放
(不像windows那樣,即使你有很多空閑內(nèi)存,他也要訪問一下磁盤中的pagefiles)
使用free命令將used的值減去buffer和cache的值就是你當前真實內(nèi)存使用
--------------
對操作系統(tǒng)來講是Mem的參數(shù).buffers/cached 都是屬于被使用,
所以它認為free只有16936.
對應(yīng)用程序來講是(-/+ buffers/cach).buffers/cached 是等同可用的,
因為buffer/cached是為了提高
程序執(zhí)行的性能,當程序使用內(nèi)存時,buffer/cached會很快地被使用。
所以,以應(yīng)用來看看,以(-/+ buffers/cache)的free和used為主.所以我們看這個就好了.
另外告訴大家一些常識.Linux為了提高磁盤和內(nèi)存存取效率, Linux做了很多精心的設(shè)計, 除了對dentry進行緩存(用于VFS,加速文件路徑名到inode的轉(zhuǎn)換),
還采取了兩種主要Cache方式:Buffer Cache和Page Cache。
前者針對磁盤塊的讀寫,后者針對文件inode的讀寫。這些Cache能有效縮短了 I/O系統(tǒng)調(diào)用(比如read,write,getdents)的時間。
記住內(nèi)存是拿來用的,不是拿來看的.不象windows,無論你的真實物理內(nèi)存有多少,他都要拿硬盤交換
文件來讀.這也就是windows為什么常常提示虛擬空間不足的原因.你們想想,多無聊,在內(nèi)存還有大部分的時候,拿出一部分硬盤空間來充當內(nèi)存.硬盤怎么會快過內(nèi)存.所以我們看linux,只要不用swap的交換空間,就不用擔心自己的內(nèi)存太少.
如果常常swap用很多,可能你就要考慮加物理內(nèi)存了.這也是linux看內(nèi)存是否夠用的標準哦.
功能說明:顯示內(nèi)存狀態(tài)。
語 法: free [-bkmotV][-s <間隔秒數(shù)>]
補充說明:free指令會顯示內(nèi)存的使用情況,包括實體內(nèi)存,虛擬的交換文件內(nèi)存,共享內(nèi)存區(qū)段,以及系統(tǒng)核心使用的緩沖區(qū)等。
參 數(shù):
-b 以Byte為單位顯示內(nèi)存使用情況。
-k 以KB為單位顯示內(nèi)存使用情況。
-m 以MB為單位顯示內(nèi)存使用情況。
-o 不顯示緩沖區(qū)調(diào)節(jié)列。
-s<間隔秒數(shù)> 持續(xù)觀察內(nèi)存使用狀況。
-t 顯示內(nèi)存總和列。
-V 顯示版本信息。
如果內(nèi)存不足,可以增加swap交換分區(qū). 具體方法請參考:
[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:表示物理內(nèi)存統(tǒng)計
-/+ buffers/cached:表示物理內(nèi)存的緩存統(tǒng)計
Swap:表示硬盤上交換分區(qū)的使用情況,這里我們不去關(guān)心。
系統(tǒng)的總物理內(nèi)存:255268Kb(256M),但系統(tǒng)當前真正可用的內(nèi)存b并不是第一行free 標記的 16936Kb,它僅代表未被分配的內(nèi)存。
第1行 Mem:
total:表示物理內(nèi)存總量。
used:表示總計分配給緩存(包含buffers 與cache )使用的數(shù)量,但其中可能部分緩存并未實際使用。
free:未被分配的內(nèi)存。
shared:共享內(nèi)存,一般系統(tǒng)不會用到,這里也不討論。
buffers:系統(tǒng)分配但未被使用的buffers 數(shù)量。
cached:系統(tǒng)分配但未被使用的cache 數(shù)量。
buffer 與cache 的區(qū)別見后面。
total = used + free
第2行 -/+ buffers/cached:
used:也就是第一行中的used - buffers-cached 也是實際使用的內(nèi)存總量。
free:未被使用的buffers 與cache 和未被分配的內(nèi)存之和,這就是系統(tǒng)當前實際可用內(nèi)存。
free 2= buffers1 + cached1 + free1 //free2為第二行、buffers1等為第一行
buffer 與cache 的區(qū)別:
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行:
第三行所指的是從應(yīng)用程序角度來看,
對于應(yīng)用程序來說,buffers/cached 是等于可用的,
因為buffer/cached是為了提高文件讀取的性能,
當應(yīng)用程序需在用到內(nèi)存的時候,buffer/cached會很快地被回收。
所以從應(yīng)用程序的角度來說,可用內(nèi)存=系統(tǒng)free memory+buffers+cached.
第二行(mem)的used/free與第三行(-/+ buffers/cache) used/free的區(qū)別。
這兩個的區(qū)別在于使用的角度來看,
第一行是從OS的角度來看,因為對于OS,buffers/cached 都是屬于被使用,所以他的可用內(nèi)存是16936KB,已用內(nèi)存是238332KB,其中包括,內(nèi)核(OS)使用+Application(X,oracle,etc)使用的+buffers+cached.
第三行所指的是從應(yīng)用程序角度來看,對于應(yīng)用程序來說,buffers/cached 是等于可用的,因為buffer/cached是為了提高文件讀取的性能,當應(yīng)用程序需在用到內(nèi)存的時候,buffer/cached會很快地被回收。
所以從應(yīng)用程序的角度來說,可用內(nèi)存=系統(tǒng)free memory+buffers+cached.
接下來解釋什么時候內(nèi)存會被交換,以及按什么方交換。
當可用內(nèi)存少于額定值的時候,就會開會進行交換.如何看額定值(RHEL4.0):
#cat /proc/meminfo
交換將通過三個途徑來減少系統(tǒng)中使用的物理頁面的個數(shù):
1.減少緩沖與頁面cache的大小,
2.將系統(tǒng)V類型的內(nèi)存頁面交換出去,
3.換出或者丟棄頁面。(Application 占用的內(nèi)存頁,也就是物理內(nèi)存不足)。
事實上,少量地使用swap是不是影響到系統(tǒng)性能的。
下面是buffers與cached的區(qū)別。
buffers是指用來給塊設(shè)備做的緩沖大小,他只記錄文件系統(tǒng)的metadata以及 tracking in-flight pages.cached是用來給文件做緩沖。那就是說:buffers是用來存儲,目錄里面有什么內(nèi)容,權(quán)限等等。
而cached直接用來記憶我們打開的文件,如果你想知道他是不是真的生效,你可以試一下,先后執(zhí)行兩次命令#man X ,你就可以明顯的感覺到第二次的開打的速度快很多。
實驗:在一臺沒有什么應(yīng)用的機器上做會看得比較明顯。記得實驗只能做一次,如果想多做請換一個文件名。
#free
#man X
#free
#man X
#free
你可以先后比較一下free后顯示buffers的大小。
另一個實驗:
#free#
ls /dev
#free
你比較一下兩個的大小,當然這個buffers隨時都在增加,但你有l(wèi)s過的話,增加的速度會變得快,這個就是buffers/chached的區(qū)別。
因為Linux將你暫時不使用的內(nèi)存作為文件和數(shù)據(jù)緩存,以提高系統(tǒng)性能,
當你需要這些內(nèi)存時,系統(tǒng)會自動釋放
(不像windows那樣,即使你有很多空閑內(nèi)存,他也要訪問一下磁盤中的pagefiles)
使用free命令將used的值減去buffer和cache的值就是你當前真實內(nèi)存使用
--------------
對操作系統(tǒng)來講是Mem的參數(shù).buffers/cached 都是屬于被使用,
所以它認為free只有16936.
對應(yīng)用程序來講是(-/+ buffers/cach).buffers/cached 是等同可用的,
因為buffer/cached是為了提高
程序執(zhí)行的性能,當程序使用內(nèi)存時,buffer/cached會很快地被使用。
所以,以應(yīng)用來看看,以(-/+ buffers/cache)的free和used為主.所以我們看這個就好了.
另外告訴大家一些常識.Linux為了提高磁盤和內(nèi)存存取效率, Linux做了很多精心的設(shè)計, 除了對dentry進行緩存(用于VFS,加速文件路徑名到inode的轉(zhuǎn)換),
還采取了兩種主要Cache方式:Buffer Cache和Page Cache。
前者針對磁盤塊的讀寫,后者針對文件inode的讀寫。這些Cache能有效縮短了 I/O系統(tǒng)調(diào)用(比如read,write,getdents)的時間。
記住內(nèi)存是拿來用的,不是拿來看的.不象windows,無論你的真實物理內(nèi)存有多少,他都要拿硬盤交換
文件來讀.這也就是windows為什么常常提示虛擬空間不足的原因.你們想想,多無聊,在內(nèi)存還有大部分的時候,拿出一部分硬盤空間來充當內(nèi)存.硬盤怎么會快過內(nèi)存.所以我們看linux,只要不用swap的交換空間,就不用擔心自己的內(nèi)存太少.
如果常常swap用很多,可能你就要考慮加物理內(nèi)存了.這也是linux看內(nèi)存是否夠用的標準哦.
相關(guān)文章
- 用free -m查看的結(jié)果: # free -m total used free shared buffers cached Mem: 504 471 32 0 19 269 -/+ buffers/cache: 183 321 Swap: 996 0 996 查看/proc/kcore文件的2009-03-10
- 先看看內(nèi)存使用狀況 [root@node1 ~]# free -m total used free shared buffers cached Mem: 8004 6557 1446 0 163 5630 -/+ buffers/cache: 763 7240 Swap: 12008-09-08
- Linux用戶進程是如何釋放內(nèi)存的 Linux進程使用內(nèi)存的基本流程: 從圖中我們可以看出,進程的堆,并不是直接建立在Linux的內(nèi)核的內(nèi)存分配策略上的,而是建立在glibc的堆2009-03-10
- linux下由top命令計算每個用戶使用內(nèi)存的大小,此功能該如何實現(xiàn),本為將詳細介紹2012-11-27
linux free命令詳解和使用實例(查看內(nèi)存使用率)
free命令可以顯示Linux系統(tǒng)中空閑的、已用的物理內(nèi)存及swap內(nèi)存,及被內(nèi)核使用的buffer。在Linux系統(tǒng)監(jiān)控的工具中,free命令是最經(jīng)常使用的命令之一2014-04-09Linux中 如何查看Ubuntu內(nèi)存信息? 查看內(nèi)存信息的命令
在Linux系統(tǒng)中如何查看Ubuntu內(nèi)存信息?這篇文章主要講述了查看Ubuntu內(nèi)存信息的命令,很實用,需要的朋友可以參考下2014-10-23- 使用top工具查看到Suse Linux的內(nèi)存占用率很大,可能97%以上,我知道這是Linux的內(nèi)存使用機制,先將內(nèi)存整個管理起來,需要的時候在分配給單個進程。但是如果我需要查看系2014-12-18