free命令linux free命令中的available内存

Linux的free命令使用方法linux系统教程:free命令使用方法
首先我们介绍命令的格式为 free [参数] 。
介绍第一条命令"free"显示内存的.使用信息 。默认按照M的计数单位统计 。
显示各个参数说明:
total表示 总计物理内存的大小 。
used表示 已使用多少 。
free表示 可用内存多少 。
Shared表示 多个进程共享的内存总额 。
Buffers/cached表示 磁盘缓存的大小 。
第三行(-/buffers/cached)解释
used:已使用多大 。
free:可用有多少 。
第四行是交换分区SWAP的,也就是我们通常所说的虚拟内存 。
我们按照系统应用程序来说:系统可用内存= 系统free buffers cached 。
相关介绍:Linux
Linux是一种自由和开放源代码的类UNIX操作系统 。
Linux拥有以下特性:类似于Unix的基本思想 , 支持完全免费与自由传播,完全兼容POSIX1.0标准,支持多用户、多任务、有着良好的界面、支持多种平台 。Linux是一个性能稳定的多用户网络操作系统 。
Linux有着许多不同的版本 。Linux可安装在各种计算机硬件设备中,比如手机、平板电脑、路由器、视频游戏控制台、台式计算机、大型机和超级计算机 。
Linux下怎么查看内存使用情况和CPU利用率?1. 在系统维护free命令linux的过程中,随时可能有需要查看 CPU 使用率,并根据相应信息分析系统状况的需要 。在 CentOS 中 , 可以通过 top 命令来查看 CPU 使用状况 。运行 top 命令后,CPU 使用状态会以全屏的方式显示,并且会处在对话的模式 -- 用基于 top 的命令,可以控制显示方式等等 。退出 top 的命令为 q (在 top 运行中敲 q 键一次) 。
top命令是Linux下常用的性能分析工具,能够实时显示系统中各个进程的资源占用状况 , 类似于Windows的任务管理器
可以直接使用top命令后,查看%MEM的内容 。可以选择按进程查看或者按用户查看,如想查看oracle用户的进程内存使用情况的话可以使用如下的命令:
$ top -u oracle
2. 释义:
PID:进程的ID
USER:进程所有者
PR:进程的优先级别,越小越优先被执行
NInice:值
VIRT:进程占用的虚拟内存
RES:进程占用的物理内存
SHR:进程使用的共享内存
S:进程的状态 。S表示休眠 , R表示正在运行,Z表示僵死状态 , N表示该进程优先值为负数
%CPU:进程占用CPU的使用率
%MEM:进程使用的物理内存和总内存的百分比
TIME :该进程启动后占用的总的CPU时间 , 即占用CPU使用时间的累加值 。
COMMAND:进程启动命令名称
3.操作实例:
在命令行中输入 “top”
即可启动 top
top 的全屏对话模式可分为3部分:系统信息栏、命令输入栏、进程列表栏 。
第一部分 -- 最上部的 系统信息栏 :
第一行(top):
“00:11:04”为系统当前时刻;
“3:35”为系统启动后到现在的运作时间;
“2 users”为当前登录到系统的用户,更确切的说是登录到用户的终端数 -- 同一个用户同一时间对系统多个终端的连接将被视为多个用户连接到系统,这里的用户数也将表现为终端的数目;
“load average”为当前系统负载的平均值,后面的三个值分别为1分钟前、5分钟前、15分钟前进程的平均数 , 一般的可以认为这个数值超过 CPU 数目时,CPU 将比较吃力的负载当前系统所包含的进程;
第二行(Tasks):
“59 total”为当前系统进程总数;
“1 running”为当前运行中的进程数;
“58 sleeping”为当前处于等待状态中的进程数;
“0 stoped”为被停止的系统进程数;
“0 zombie”为被复原的进程数;
第三行(Cpus):
分别表示free命令linux了 CPU 当前的使用率;
第四行(Mem):
分别表示free命令linux了内存总量、当前使用量、空闲内存量、以及缓冲使用中的内存量;
第五行(Swap):
表示类别同第四行(Mem),但此处反映着交换分区(Swap)的使用情况 。通常,交换分区(Swap)被频繁使用的情况 , 将被视作物理内存不足而造成的 。
第二部分 -- 中间部分的内部命令提示栏:
top 运行中可以通过 top 的内部命令对进程的显示方式进行控制 。内部命令如下表:
s
- 改变画面更新频率
l - 关闭或开启第一部分第一行 top 信息的表示
t - 关闭或开启第一部分第二行 Tasks 和第三行 Cpus 信息的表示
m - 关闭或开启第一部分第四行 Mem 和 第五行 Swap 信息的表示
N - 以 PID 的大小的顺序排列表示进程列表(第三部分后述)
P - 以 CPU 占用率大小的顺序排列进程列表 (第三部分后述)
M - 以内存占用率大小的顺序排列进程列表 (第三部分后述)
h - 显示帮助
n - 设置在进程列表所显示进程的数量
q - 退出 top
s -
改变画面更新周期
第三部分 -- 最下部分的进程列表栏:
以 PID 区分的进程列表将根据所设定的画面更新时间定期的更新 。通过 top 内部命令可以控制此处的显示方式
【free命令linux free命令中的available内存】pmap
可以根据进程查看进程相关信息占用的内存情况,(进程号可以通过ps查看)如下所示:
$ pmap -d 5647
ps
如下例所示:
$ ps -e -o 'pid,comm,args,pcpu,rsz,vsz,stime,user,uid'其中rsz是是实际内存
$ ps -e -o 'pid,comm,args,pcpu,rsz,vsz,stime,user,uid' | grep oracle |sort -nrk
其中rsz为实际内存,上例实现按内存排序,由大到小
在Linux下查看内存我们一般用free命令:
[root@scs-2 tmp]# free
totalusedfreesharedbufferscached
Mem:326618032500041617601106522668236
-/buffers/cache:4711162795064
Swap:2048276801601968116
下面是对这些数值的解释:
total:总计物理内存的大小 。
used:已使用多大 。
free:可用有多少 。
Shared:多个进程共享的内存总额 。
Buffers/cached:磁盘缓存的大小 。
第三行(-/buffers/cached):
used:已使用多大 。
free:可用有多少 。
第四行就不多解释了 。
区别:第二行(mem)的used/free与第三行(-/buffers/cache) used/free的区别 。这两个的区别在于使用的角度来看,第一行是从OS的角度来看,因为对于OS,buffers/cached 都是属于被使用,所以free命令linux他的可用内存是16176KB,已用内存是3250004KB,其中包括,内核(OS)使用 Application(X, oracle,etc)使用的 buffers cached.
第三行所指的是从应用程序角度来看,对于应用程序来说,buffers/cached 是等于可用的,因为buffer/cached是为了提高文件读取的性能,当应用程序需在用到内存的时候,buffer/cached会很快地被回收 。
所以从应用程序的角度来说,可用内存=系统free memory buffers cached 。
如上例:
2795064=16176 110652 2668236
接下来解释什么时候内存会被交换 , 以及按什么方交换 。当可用内存少于额定值的时候,就会开会进行交换 。
如何看额定值:
cat /proc/meminfo
[root@scs-2 tmp]# cat /proc/meminfo
MemTotal:3266180 kB
MemFree:17456 kB
Buffers:111328 kB
Cached:2664024 kB
SwapCached:0 kB
Active:467236 kB
Inactive:2644928 kB
HighTotal:0 kB
HighFree:0 kB
LowTotal:3266180 kB
LowFree:17456 kB
SwapTotal:2048276 kB
SwapFree:1968116 kB
Dirty:8 kB
Writeback:0 kB
Mapped:345360 kB
Slab:112344 kB
Committed_AS:535292 kB
PageTables:2340 kB
VmallocTotal: 536870911 kB
VmallocUsed:272696 kB
VmallocChunk: 536598175 kB
HugePages_Total:0
HugePages_Free:0
Hugepagesize:2048 kB
用free -m查看的结果:
[root@scs-2 tmp]# free -m
totalusedfreesharedbufferscached
Mem:318931731601072605
-/buffers/cache:4602729
Swap:2000781921
查看/proc/kcore文件的大?。诖婢迪瘢?
[root@scs-2 tmp]# ll -h /proc/kcore
-r-------- 1 root root 4.1G Jun 12 12:04 /proc/kcore
备注:
占用内存的测量
测量一个进程占用了多少内存,linux为我们提供了一个很方便的方法,/proc目录为我们提供了所有的信息,实际上top等工具也通过这里来获取相应的信息 。
/proc/meminfo 机器的内存使用信息
/proc/pid/maps pid为进程号,显示当前进程所占用的虚拟地址 。
/proc/pid/statm 进程所占用的内存
[root@localhost ~]# cat /proc/self/statm
654 57 44 0 0 334 0
输出解释
CPU 以及CPU0 。。。的每行的每个参数意思(以第一行为例)为:
参数 解释 /proc//status
Size (pages) 任务虚拟地址空间的大小 VmSize/4
Resident(pages) 应用程序正在使用的物理内存的大小 VmRSS/4
Shared(pages) 共享页数 0
Trs(pages) 程序所拥有的可执行虚拟内存的大小 VmExe/4
Lrs(pages) 被映像到任务的虚拟内存空间的库的大小 VmLib/4
Drs(pages) 程序数据段和用户态的栈的大小 (VmDataVmStk )4
dt(pages) 04
查看机器可用内存
/proc/28248/free
total used free shared buffers cached
Mem: 1023788 926400 97388 0 134668 503688
-/buffers/cache: 288044 735744
Swap: 1959920 89608 1870312
我们通过free命令查看机器空闲内存时,会发现free的值很小 。这主要是因为,在linux中有这么一种思想,内存不用白不用,因此它尽可能的cache和buffer一些数据,以方便下次使用 。但实际上这些内存也是可以立刻拿来使用的 。
所以 空闲内存=free buffers cached=total-used
top命令 是Linux下常用的性能 分析工具 ,能够实时显示系统 中各个进程的资源占用状况,类似于Windows的任务管理 器 。下面详细介绍它的使用方法 。
top - 02:53:32 up 16 days,6:34, 17 users,load average: 0.24, 0.21, 0.24
Tasks: 481 total,3 running, 474 sleeping,0 stopped,4 zombie
Cpu(s): 10.3\us,1.8%sy,0.0%ni, 86.6%id,0.5%wa,0.2%hi,0.6%si,0.0%st
Mem:4042764k total,4001096k used,41668k free,383536k buffers
Swap:2104472k total,7900k used,2096572k free,1557040k cached
PID USERPRNIVIRTRESSHR S %CPU %MEMTIMECOMMAND
32497 jacky200669m 222m31m R105.629:27.62 firefox
4788 yiuwing200257m18m13m S50.55:42.44 konsole
5657 Liuxiaof200585m 159m30m S44.05:25.06 firefox
4455 xiefc200542m124m30m R43.17:23.03 firefox
6188 Liuxiaof200191m17m13m S40.50:01.16 konsole
统计信息区前五行是系统整体的统计信息 。第一行是任务队列信息 , 同 uptime命令的执行结果 。其内容如下:
01:06:48当前时间
up 1:22系统运行 时间,格式为时:分
1 user当前登录用户 数
load average: 0.06, 0.60, 0.48系统负载 ,即任务队列的平均长度 。
三个数值分别为1分钟、5分钟、15分钟前到现在的平均值 。
第二、三行为进程和CPU的信息 。当有多个CPU时,这些内容可能会超过两行 。内容如下:
Tasks: 29 total进程总数
1 running正在运行的进程数
28 sleeping睡眠的进程数
0 stopped停止的进程数
0 zombie僵尸进程数
Cpu(s): 0.3% us用户空间占用CPU百分比
1.0% sy内核 空间占用CPU百分比
0.0% ni用户进程空间内改变过优先级的进程占用CPU百分比
98.7% id空闲CPU百分比
0.0% wa等待输入输出的CPU时间百分比
0.0% hi
0.0% si
最后两行为内存 信息 。内容如下:
Mem: 191272k total物理内存总量
173656k used使用的物理内存总量
17616k free空闲内存总量
22052k buffers用作内核缓存 的内存量
Swap: 192772k total交换区总量
0k used使用的交换区总量
192772k free空闲交换区总量
123988k cached缓冲的交换区总量 。
内存中的内容被换出到交换区 , 而后又被换入到内存,但使用过的交换区尚未被覆盖,
该数值即为这些内容已存在于内存中 的交换区的大小 。
相应的内存再次被换出时可不必再对交换区写入 。
进程信息区统计信息区域的下方显示了各个进程的详细信息 。首先来认识一下各列的含义 。
序号列名含义
aPID进程id
bPPID父进程id
cRUSERReal user name
dUID进程所有者的用户id
eUSER进程所有者的用户名
fGROUP进程所有者的组名
gTTY启动进程的终端名 。不是从终端启动的进程则显示为 ?
hPR优先级
iNInice值 。负值表示高优先级,正值表示低优先级
jP最后使用的CPU,仅在多CPU环境 下有意义
k%CPU上次更新到现在的CPU时间占用百分比
lTIME进程使用的CPU时间总计,单位秒
mTIME进程使用的CPU时间总计,单位1/100秒
n%MEM进程使用的物理内存 百分比
oVIRT进程使用的虚拟内存总量,单位kb 。VIRT=SWAP RES
pSWAP进程使用的虚拟内存中,被换出的大小,单位kb 。
qRES进程使用的、未被换出的物理内存大?。ノ籯b 。RES=CODE DATA
rCODE可执行代码占用的物理 内存大小 , 单位kb
sDATA可执行代码以外的部分(数据 段 栈)占用的物理 内存大?。?单位kb
tSHR共享内存大?。?单位kb
unFLT页面错误次数
vnDRT最后一次写入到现在,被修改过的页面数 。
wS进程状态 。
D =不可中断的睡眠状态
R =运行
S =睡眠
T =跟踪/停止
Z =僵尸进程
xCOMMAND命令名/命令行
yWCHAN若该进程在睡眠 , 则显示睡眠中的系统函数名
zFlags任务标志 , 参考 sched.h
默认情况下仅显示比较重要的PID、USER、PR、NI、VIRT、RES、SHR、S、%CPU、%MEM、TIME 、COMMAND列 。可以通过下面的快捷键来更改显示内容 。
更改显示内容通过 f 键可以选择显示的内容 。按 f 键之后会显示列的列表,按 a-z即可显示或隐藏对应的列,最后按回车键确定 。
按 o 键可以改变列的显示顺序 。按小写的 a-z 可以将相应的列向右移动,而大写的 A-Z可以将相应的列向左移动 。最后按回车键确定 。
按大写的 F 或 O 键,然后按 a-z 可以将进程按照相应的列进行排序 。而大写的R 键可以将当前的排序倒转 。
==============================
top命令使用过程中,还可以使用一些交互的命令来完成其它参数的功能 。这些命令是通过快捷键启动的 。
<空格>:立刻刷新 。
P:根据CPU使用大小进行排序 。
T:根据时间、累计时间排序 。
q:退出top命令 。
m:切换显示内存信息 。
t:切换显示进程和CPU状态信息 。
c:切换显示命令名称和完整命令行 。
M:根据使用内存大小进行排序 。
W:将当前设置写入~/.toprc文件中 。这是写top配置文件的推荐方法 。
可以看到,top命令是一个功能十分强大的监控系统的工具,对于系统管理员而言尤其重要 。但是,它的缺点是会消耗很多系统资源 。
应用实例
使用top命令可以监视指定用户,缺省情况是监视所有用户的进程 。如果想查看指定用户的情况,在终端中按“U”键,然后输入用户名,系统就会切换为指定用户的进程运行界面 。
a.作用
free命令用来显示内存的使用情况,使用权限是所有用户 。
b.格式
free [-b?。璳?。璵] [-o] [-s delay] [-t] [-V]
c.主要参数
-b -k -m:分别以字节(KB、MB)为单位显示内存使用情况 。
-s delay:显示每隔多少秒数来显示一次内存使用情况 。
-t:显示内存总和列 。
-o:不显示缓冲区调节列 。
d.应用实
Linux查看系统资源占用Linux查看系统资源占用
复制自:
在系统维护的过程中,随时可能有需要查看 CPU和内存的使用率,并根据相应信息分析系统状况的需求 。本文介绍一下几种常见的Linux系统资源查看命令 。
1、总体内存占用的查看
命令:free
图1 free命令查看内存占用
(1) free命令默认是以kb为单位显示的,可以用free -m 用Mb单位来显示 。
(2) Mem行 : total = usedfree 其中buffers和cached虽然计算在used内,但其实为可用内存 。
(3) Mem下一行:used为真实已占内存 , free为真实可用内存 。
(4)Swap:内存交换区的使用情况 。
2、查看内存占用前五的进程
命令:ps auxw | head -1;ps auxw|sort -rn -k4|head -5
图 2.1查看内存占用前5的进程
如图2.1所示,内存的单位是kb , VSZ是虚拟内存的占用,RSS是真实的内存的占用 。
命令分解:
ps auxw显示系统资源占用情况;
head -1表示显示第一列,即标题列;
sort -r 表示反向排序,-n表示按数字排序 , -k4表示列的第4个字符 。
3、查看CPU占用前三的进程
命令:ps auxw|head -1;ps auxw|sort -rn -k3|head -3
图3.1 查看cpu占用前三的进程
该命令与图2.1相仿,只是选择的资源占用情况的第3列(即cpu),用“-k3”表示 。
4、查看系统整体的负载
命令:top
图4.1 top显示系统整体负载
(1)第一行: 系统时间系统运行时间几个用户1/5/15分钟系统平均负载
(2)第二行:进程总数(total)正在运行进程数(running)睡眠进程数(sleeping)停止的进程数(stopped)僵尸进程数(zombie)
(3)第三行:用户空间CPU占比(us)内核空间CPU占比(sy)CPU空置率(id)
图4.2 各个任务占用资源情况
注解:
PID :进程ID
USER :用户名
PR :优先级
NI :负值表示高优先级,正值表示低优先级 。
VIRT :虚拟内存
RES : 真实内存
SHR :共享内存
S :进程状态 D=不可中断的睡眠状态; R=运行; S=睡眠 ;T=跟踪/停止; Z=僵尸进程
参数:
top -d 2 :每隔2秒显式所有进程的资源占用情况
top -c :每隔5秒显式进程的资源占用情况,并显示进程的命令行参数(默认只有进程名)
top -p 12345 -p 6789:每隔5秒显示pid是12345和pid是6789的两个进程的资源占用情况
top -d 2 -c -p 123456 :每隔2秒显示pid是12345的进程的资源使用情况,并显式该进程启动的命令行参数
Linux命令行查看内存 用 'top -i' 看看有多少进程处于 Running 状态 , 可能系统存在内存或 I/O 瓶颈,用 free 看看系统内存使用情况,swap 是否被占用很多 , 用 iostat 看看 I/O 负载情况...
还有一种办法是 ps -ef | sort -k7 ,将进程按运行时间排序,看哪个进程消耗的cpu时间最多 。
top:
主要参数 :
free
1.作用
free命令用来显示内存的使用情况,使用权限是所有用户 。
**2.格式 **
**3.主要参数 **
uptime
vmstat
**1 观察磁盘活动情况 **
磁盘活动情况主要从以下几个指标了解:
**2 观察cpu活动情况 **
vmstat比top更能反映出cpu的使用情况:
iostat
用于统计CPU的使用情况及tty设备、硬盘和CD-ROM的I/0量
即使爬到最高的山上,一次也只能脚踏实地地迈一步 。
Linux查看CPU和内存使用情况:
在做Linux系统优化的时候,物理内存是其中最重要的一方面 。自然的,Linux也提供了非常多的方法来监控宝贵的内存资源的使用情况 。下面的清单详细的列出了Linux系统下通过视图工具或命令行来查看内存使用情况的各种方法 。
1. /proc/meminfo
查看RAM使用情况最简单的方法是通过 /proc/meminfo。这个动态更新的虚拟文件实际上是许多其他内存相关工具(如:free / ps / top)等的组合显示 。/proc/meminfo 列出了所有你想了解的内存的使用情况 。进程的内存使用信息也可以通过/proc/pid/statm 和 /proc/pid/status 来查看 。
atop命令是一个终端环境的监控命令 。它显示的是各种系统资源(CPU, memory, network, I/O, kernel)的综合,并且在高负载的情况下进行了彩色标注 。
free命令是一个快速查看内存使用情况的方法,它是对 /proc/meminfo 收集到的信息的一个概述 。
GNOME System Monitor 是一个显示最近一段时间内的CPU、内存、交换区及网络的使用情况的视图工具 。它还提供了一种查看CPU及内存使用情况的方法 。
htop命令显示了每个进程的内存实时使用率 。它提供了所有进程的常驻内存大小、程序总内存大小、共享库大小等的报告 。列表可以水平及垂直滚动 。
功能同 4 中介绍的GENOME版本 。
memstat是一个有效识别executable(s), process(es) and shared libraries使用虚拟内存情况的命令 。给定一个进程ID,memstat可以列出这个进程相关的可执行文件、数据和共享库 。
nmon是一个基于ncurses的系统基准测试工具,它可以监控CPU、内存、I/O、文件系统及网络资源等的互动模式 。对于内存的使用,它可以实时的显示 总/剩余内存、交换空间等信息 。
ps命令可以实时的显示各个进程的内存使用情况 。Reported memory usage information includes %MEM (percent of physical memory used), VSZ (total amount of virtual memory used), and RSS (total amount of physical memory used) 。你可以使用 “–sort”选项对进程进行排序,例如按RSS进行排序:
smem命令允许你统计基于/proc信息的不同进程和用户的内存使用情况 。内存使用情况的分析可以导出图表(如条形图和饼图) 。
top命令提供了实时的运行中的程序的资源使用统计 。你可以根据内存的使用和大小来进行排序 。
vmstat命令显示实时的和平均的统计,覆盖CPU、内存、I/O等内容 。例如内存情况,不仅显示物理内存,也统计虚拟内存 。
正确理解linux运行内存过高的问题以及free命令周末闲来无事free命令linux,查看free命令linux了一下服务器的运行状态 。发现通过监控页面可以看到free命令linux,服务器的运行内存一直占用在98%左右free命令linux,难道服务器出现什么问题了free命令linux???
后来通过了解到,linux系统和平时使用的windwos系统内存运行机制不同 。
windows系统的内存是程序运行过程中需要使用才会用到,不用时空闲着 。所以当内存使用率过高时 , 需要检查是否超负载运行 。解决方法是停止掉一些进程 。
linux系统中,是进程优先使用内存,而不是磁盘 。这样会加快读取速度 。当有新的进程启动时,再从内存中开辟出一定空间,为新的进程所用 。即使进程退出,也不会立刻从内存中清理掉,这样可以加快下次启动进程的速度 。所以内存一直是使用率很高的 。这是linux系统的独特之处,初使用linux系统的同学需要转换一些思维 。不用为linux的内存使用率高而担心 。
在图1中,第三行反映出真实内存使用率为12.5%
再介绍一个linux查看内存的命令,free
free命令可以显示当前系统为使用和以使用的内存情况 , 还可以显示被内存使用的内存缓冲区 。
free命令默认以K单位来显示内存使用情况
Mem行显示数据
total:总内存大小
used:已使用内存大小
free:当前空闲内存大小
shared:多个进程共享的内存总额
buffers/cached:缓存内存数据
-/buffers/cache行数据显示
这一行的数据代表应用内存使用情况,可理解为真实内存使用情况 。如图1中第三行数据 。
used:当前(真实)使用内存总数
free:当前(真实)空闲内存总数
-/buffers/cache:10256047165460可理解为当前已经使用的内存为1/8,计算公式used/(used free) 。也就是12.6%左右 。
Swap代表交换分区,不做过多详解
free常用参数:
free -b#以Byte为单位显示内存使用情况
free -k#以KB为单位显示内存使用情况 , 也是默认参数
free -m#以MB为单位显示内存使用情况
free -g#以GB为单位显示内存使用情况
free -o#不显示应用(真实)内存使用情况列,不推荐
free -s数字 #间隔数字秒数刷新显示内存使用情况
free -t#显示内存总和列
free -V#显示当前版本
free命令linux的介绍就聊到这里吧,感谢你花时间阅读本站内容,更多关于free命令中的available内存、free命令linux的信息别忘了在本站进行查找喔 。

    推荐阅读