linux内存查看命令使用情况(linux内存使用率)

linux内存查看命令使用情况(linux内存使用率)

Linux下使用什么方法来查看内存的使用情况呢?我想监视Linux系统的内存使用情况,在Linux下有哪些视图或者命令行工具可用呢?

在做Linux系统优化的时候,物理内存是其中最重要的一方面。自然的,Linux也提供了非常多的方法来监控宝贵的内存资源的使用情况。下面的清单详细的列出了Linux系统下通过视图工具或命令行来查看内存使用情况的各种方法

一、free

  对于free命令,可以加上-m参数,使其显示单位为Mb。如下:

[linuxidc@Ubuntu ~]$>free
total used free shared buffers cachedMem: 1008504 547364 461140 12836 53984 254508-/ buffers/cache: 238872 769632Swap: 1046524 0 1046524

[linuxidc@ubuntu ~]$>free-m total used free shared buffers cachedMem: 984 534 450 12 52 248-/ buffers/cache: 233 751Swap: 1021 0 1021

  这里出现了一些名词,有些是我不知道的,我专门去查了一下它们所代表的含义。

totalusedfreesharedbufferscachedMem表示物理 内存总量

表示总计分配给缓存(包含buffers 与cache )使用的数量,但其中可能部分缓存并未实际使用

未被分配的内存共享内存系统分配但未被使用的buffers 数量系统分配但未被使用的cache 数量实际使用的buffers 与cache 总量,也是实际使用的内存总量未被使用的buffers 与cache 和未被分配的内存之和,这就是系统当前实际可用内存Swap

  同样是做为缓存,buffers和cache又有啥区别呢?

  于是又查了些资料,发现buffers实际应该是叫“缓冲”,其英文解释是:A buffer is something that has yet to be “written” to disk.

  就是说,buffers是将要写入硬盘中的数据缓存。

  而cache的英文解释:A cache is something that has been “read” from the disk and stored for later use.

  就是说,cache是从硬盘或者存储设备读进计算机后缓存在内存中的数据。

  想起看《计算机组成原理》的时候,有看到因特尔的cpu与内存之间有cache,这之间好像有什么区别的样子。

  继续查资料,发现了page cache 和 buffer cache。简单说来,page cache用来缓存文件数据,buffer cache用来缓存磁盘数据。在有文件系统的情况下,对文件操作,那么数据会缓存到page cache,如果直接采用dd等工具对磁盘进行读写,那么数据会缓存到buffer cache。

  对于cache和buffer,cached是cpu与内存间的,buffer是内存与磁盘间的,都是为了解决速度不对等的问题。

  在free中,buffer 是buffer cache的内存,是块设备的读写缓冲区;cache是page cache的内存, 文件系统的cache。

  关于buffer与chche,这里就不多说了,最后的链接5里讲得挺清楚了。

  这里还有一个名词,Swap,即虚拟内存。当物理内存不够用的时候,就要释放掉一部分空间,以供当前运行程序使用。这些被释放掉的内存的数据就被临时保存在虚拟内存中。但是,并非所有的数据都全被保存,只有那些使用malloc或new生成的对象,他们在文件中并没有相应的“储备”文件,被称为匿名内存数据,需要临时地存进Swap。故Swap又称匿名数据交换空间。在链接3中有其说明。

  至于shared,暂时没查到与之相关的资料,只是在某链接里提了一下其不常用。

二、top命令

  top命令就好像是“linux下的任务管理器”:

  其中,第一行的内容与uptime命令的结果是一样的

[linuxidc@ubuntu ~]$>uptime
10:05:01 up 34 min, 1 user, load average: 0.00, 0.11, 0.16

  第二行的名词也比较好理解,就是进程总数与处于R、S、T、Z状态下的进程数:

Taskstotalrunningsleepingstoppedzombie总数执行等待(睡眠)暂停僵尸181217900

  第三行就是CPU的使用情况了,如下:

%Cpu(s)us用户空间占用CPU百分比sy内核空间占用CPU百分比ni用户进程空间内改变过优先级的进程占用CPU百分比id空闲CPU百分比wa等待输入输出的CPU时间百分比hiCPU服务于硬件中断所耗费的时间总额siCPU服务软中断所耗费的时间总额stSteal Time

  第四、五行就是内存的使用情况了,和free命令里相似。

  然后是列表的含义:

PID进程IDUSER进程所有者PR优先级NInice值,负值表示高优先级,正值表示低优先级VIRT进程使用的虚拟内存总量RES进程使用的、未被换出的物理内存大小SHR共享内存大小S进程状态%CPU上次更新到现在的CPU时间占用百分比%MEM进程使用的物理内存百分比TIME 进程使用CPU总时间COMMAND命令名、命令行

默认情况下只显示这些比较重要的信息。在TOP界面下,按f可以修改显示的内容。这个界面我并不是很懂,就不叙述了。

三、vmstat命令

[linuxidc@ubuntu ~]$>vmstat
procs ———–memory———- —swap– —–io—- -system– ——cpu—–
r b swpd free buff cache si so bi bo in cs us sy id wa st 0 0 76 187932 154112 372228 0 0 143 32 36 90 1 1 94 3 0

  具体参数如下表:

rThe number of processes waiting for run time. 处于运行队列中的内核线程数目(进程数)。bThe number of processes in uninterruptible sleep.置于等待队列(等待资源、等待输入/输出)的内核线程数目。 处于block队列中不可中断的进程数swpdthe amount of virtual memory used.可用的虚拟交换内存freethe amount of idle memory.空闲内存buffthe amount of memory used as buffers.已用缓冲数目cachethe amount of memory used as cache.已用缓存数目siAmount of memory swapped in from disk (/s).从磁盘到内存的交换页数?????? (单位/S)soAmount of memory swapped to disk (/s).从交换内存到磁盘的交换页数目(单位/S)biBlocks received from a block device (blocks/s).接收到块设备的块数(块/秒)boBlocks sent to a block device (blocks/s).发送到块设备的块数(块/秒)inThe number of interrupts per second, including the clock.每秒中断数,包括时钟中断csThe number of context switches per second.每秒上下文切换数usTime spent running non-kernel code. (user time, including nice time)用户时间,处于用户模式的时间百分比syTime spent running kernel code. (system time)系统时间,处于内核模式的时间百分比idTime spent idle. Prior toLinux2.5.41, this includes IO-wait time.CPU空闲时间,空闲时间百分比waTime spent waiting for IO. Prior to Linux 2.5.41, included in idle.CPU 空闲时间,在此期间系统有未完成的磁盘/NFS I/O 请求wtTime stolen from a virtual machine. Prior to Linux 2.6.11, unknown.来自于虚拟机偷取的CPU所占的百分比(这个不会翻译…)嵌入式Linux中文站

最专业的中文嵌入式Linux网站,8年磨剑,注册用户数万人!

分享嵌入式 & Linux技术干货、教程、资讯、高薪职位

投稿admin@embeddedlinux.org.cn

发表评论

登录后才能评论