手机
当前位置:查字典教程网 >操作系统 >unix linux >Linux中虚拟内存查看命令vmstat的使用教程
Linux中虚拟内存查看命令vmstat的使用教程
摘要:vmstat是一个查看虚拟内存使用状况的工具,它可以看到服务器使用率,内存使用,虚拟内存交换情况,IO读写.相比top,可以看到整个机器的C...

vmstat是一个查看虚拟内存使用状况的工具,它可以看到服务器使用率,内存使用,虚拟内存交换情况,IO读写.相比top,可以看到整个机器的CPU,memory,IO的使用情况,而不是单单看到各个进程各值的使用率.

默认情况下,vmstat命令并没有安装,需要安装sysstat包,该包里含有vmstat程序.

一般经常使用的该命令后加2个数字参数,第一个参数是采样的时间间隔(秒),第二个参数是采样的次数.

基本参数:

vmstat [-a] [-n] [-t] [-S unit] [delay [ count]]

[-a]:显示活跃和非活跃内存

[-n]:只在开始时显示一次字段名,针对多次收集信息的情况输出人性化一点

[-t]:在每条信息的末尾,显示收集信息的时间

[-S unit]:使用指定单位显示。参数有 k 、K 、m 、M ,分别代表1000、1024、1000000、1048576字节(byte)。默认单位为K(1024 bytes)

[delay [count]]:delay是信息收集间隔,count是信息收集的次数

vmstat [-s] [-n] [-S unit]

[-s]:显示内存相关的统计信息

vmstat [-m] [-n] [delay [ count]]

[-m]:显示slabinfo,slabinfo信息记录在/proc/slabinfo文件中。slab是linux的一个内存分配机制。

vmstat [-d] [-n] [delay [ count]]

[-d]:显示相关磁盘的统计信息

注:这个跟楼下-p的区别统计信息的不同、统计对象这个是磁盘-p是子分区、这个不能指定全部输出

vmstat [-p disk partition] [-n] [delay [ count]]

[-p disk partition]:显示磁盘子分区的统计信息,这里没有iostat的信息那么有用

vmstat [-f]

[-f]:开机启动至今的fork数量 注:这里的fork应该是内核的fork()函数,在父进程中,fork返回新创建子进程的进程ID

vmstat [-V]

[-V]:版本信息

示例

root@192.168.22.54:~# vmstat 2 10

procs -----------memory---------- ---swap-- -----io---- --system-- -----cpu-----

r b swpd free buff cache si so bi bo in cs us sy id wa st

13 0 0 542604 323512 12356052 0 0 0 2 0 0 17 18 65 0 0

42 0 0 552500 323512 12356112 0 0 0 0 18669 49903 42 45 14 0 0

72 0 0 563416 323512 12356132 0 0 0 0 18394 49895 41 43 16 0 0

73 0 0 570924 323512 12356164 0 0 0 0 19666 51678 37 41 22 0 0

13 0 0 581208 323512 12356204 0 0 0 280 18990 49541 43 43 15 0 0

18 0 0 587148 323512 12356228 0 0 0 32 19360 49203 37 39 24 0 0

27 0 0 520016 323512 12356292 0 0 0 0 20423 52865 39 40 21 0 0

18 0 0 527512 323512 12356336 0 0 0 0 19613 53052 42 43 16 0 0

23 0 0 538608 323512 12356376 0 0 0 0 18860 50645 41 42 18 0 0

80 0 0 548608 323512 12356444 0 0 0 0 19781 50917 41 42 17 0 0

根据以上实例,下面是字段说明:

Procs(进程)

r:表示运行队列的进程数量,换句话说就是多少个进程真正分配到cpu.服务器配置cpu为8核,这里由于服务器运行了大量的程序在跑,当这个值超过了cpu数目,且id较小,就可能会出现cpu瓶颈.运行队列过大,表示cpu很繁忙,一般会造成cpu使用率过高.

b:等待io的进程数.

Memory

swpd:虚拟内存使用情况,单位KB

free:空闲的内存

buff:用作缓冲的内存大小,内存中的一部分,某程序代码缓存,不可移到swap里去.

cache:用作缓存的内存大小,数据缓存,允许交给swap

Swap

si:从磁盘交换到内存的交换页数量,每秒从磁盘读入虚拟内存的大小,如果这个值大于0,表示物理内存不够用或者内存泄露.

so:从内存交换到磁盘的交换页数量,每秒虚拟内存写入磁盘的大小,如果这个值大于0,表示物理内存不够用或者内存泄露.

bi:Blocks received from a block device (blocks/s).每秒从块设备接收到的块数,即读块设备。

bo:Blocks sent to a block device (blocks/s).每秒发送到块设备的块数,即写块设备。

System

in:每秒中断数,包括时钟中断.

cs:每秒上下文切换数.这个值越小越好.比如每次调用系统函数,线程的切换,代码就会进入内核空间,导致上下文切换,次数过多表示cpu大部分浪费在上下文切换,导致cpu没有充分利用.

CPU(以百分比表示)

us:用户进程执行的时间,用户cpu使用率,操作运算等.

sy:系统进程执行的时间,系统cpu使用率,读取硬盘,操作硬件等.

id:空闲时间(包括IO等待时间)

wa:等待IO时间

【Linux中虚拟内存查看命令vmstat的使用教程】相关文章:

Linux系统中cat命令使用的实例教程

ln命令的用法

Linux下虚拟域名的实现(2)

linux中的常用命令小结

Linux系统中的mount挂载磁盘命令使用教程

Linux tcpdump命令的用法详细解析

Linux系统中强大的文本操作命令tr的使用讲解

linux vsftp 虚拟用户配置方法

Linux 下rename 命令的用法第1/2页

Linux下虚拟域名的实现(3)

精品推荐
分类导航