这篇文章主要介绍vmstat命令怎么用,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!

vmstat命令是最常见的Linux/Unix监控工具,可以展现给定时间间隔的服务器的状态值,包括服务器的CPU使用率,内存使用,虚拟内存交换情况,IO读写情况。

vmstat 工具提供了一种低开销的系统性能观察方式。 (1)用法 用法: vmstat [选项参数] 或 vmstat [选项参数] [数字] [数字] (2)功能: 功能: 报告虚拟内存的统计信息,关于进程、内存、I/O等系统整体运行状态。 (3)选项参数: \1) -d:        显示磁盘相关统计信息。 \2) -a:       显示活跃和非活跃内存 \3) -f:        显示从系统启动至今的fork数量。 \4) -p:       显示指定磁盘分区统计信息 \5) -s:       显示内存相关统计信息及多种系统活动数量。 \6) -m:       显示slabinfo (4)实例:

1) 、vmstat显示虚拟内存使用情况

linuxidc@linuxidc:~$vmstatprocs-----------memory-------------swap-------io-----system--------cpu-----rb交换空闲缓冲缓存sisobiboincsussyidwast4001562526101687175200762953138119800

字段说明:

1.Procs(进程)

r: 运行队列中进程数量,这个值也可以判断是否需要增加CPU。(长期大于1)

b: 等待IO的进程数量。

2.Memory(内存)

swpd: 使用虚拟内存大小,如果swpd的值不为0,但是SI,SO的值长期为0,这种情况不会影响系统性能。

free: 空闲物理内存大小。

buff: 用作缓冲的内存大小。

cache: 用作缓存的内存大小,如果cache的值大的时候,说明cache处的文件数多,如果频繁访问到的文件都能被cache处,那么磁盘的读IO bi会非常小。

3.Swap

si: 每秒从交换区写到内存的大小,由磁盘调入内存。

so: 每秒写入交换区的内存大小,由内存调入磁盘。

注意:

内存够用的时候,这2个值都是0,如果这2个值长期大于0时,系统性能会受到影响,磁盘IO和CPU资源都会被消耗。有些朋友看到空闲内存(free)很少的或接近于0时,就认为内存不够用了,不能光看这一点,还要结合si和so,如果free很少,但是si和so也很少(大多时候是0),那么不用担心,系统性能这时不会受到影响的。

4.IO(现在的Linux版本块的大小为1kb)

bi: 每秒读取的块数

bo: 每秒写入的块数

注意:

随机磁盘读写的时候,这2个值越大(如超出1024k),能看到CPU在IO等待的值也会越大。

5.system(系统)

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

cs: 每秒上下文切换数。

注意:

上面2个值越大,会看到由内核消耗的CPU时间会越大。

6.CPU(以百分比表示)

us: 用户进程执行时间百分比(user time) us的值比较高时,说明用户进程消耗的CPU时间多,但是如果长期超50%的使用,那么我们就该考虑优化程序算法或者进行加速。

sy: 内核系统进程执行时间百分比(system time) sy的值高时,说明系统内核消耗的CPU资源多,这并不是良性表现,我们应该检查原因。

wa: IO等待时间百分比 wa的值高时,说明IO等待比较严重,这可能由于磁盘大量作随机访问造成,也有可能磁盘出现瓶颈(块操作)。

id: 空闲时间百分比

2)每二秒显示一次系统内存的统计信息

linuxidc@linuxidc:~$vmstat2procs-----------memory-------------swap-------io-----system--------cpu-----rb交换空闲缓冲缓存sisobiboincsussyidwast40011325661612889820007429531431198000001132566161288982000006020911990000011325661620889820000852157019900100999766162089035600003672337317630010099724616208903560000534250835956002009972461620890340000015084510387001500971966166089036800013478464162820000010938861680890208000162526460437125100

3)、vmstat每二秒显示一次系统内存的统计信息,总共5次

linuxidc@linuxidc:~/桌面/www.linuxidc.com$ vmstat 2 5 procs ———–memory———- —swap– —–io—- -system– ——cpu—– r b 交换 空闲 缓冲 缓存 si so bi bo in cs us sy id wa st 5 0 0 111612 61776 889992 0 0 74 29 54 146 1 1 98 0 0 0 0 0 111360 617706 889992 0 0 0 0 58 201 1 1 99 0 0 0 0 0 111360 61784 889984 0 0 0 12 54 161 1 1 98 1 0 0 0 0 111360 61784 889992 0 0 0 0 55 163 1 1 98 0 0 0 0 0 111360 61784 889992 0 0 0 0 52 155 1 1 99 0 0

4)、vmstat -d 显示磁盘的信息

linuxidc@linuxidc:~/桌面/www.linuxidc.com$vmstat-ddisk-------------reads------------------------writes----------------IO------总用量merged扇区ms总用量merged扇区mscursecloop0430676447000000loop1380226450000000loop25402124998000000loop3420674695000000loop4370664117000000loop5440678549000000loop6400230127000000loop76202140846000000sda23949316616215382212579490108476548562217060117sr0350213264000000loop814380480227055000002loop9216024762324000000loop10400670567000000loop1192021622091000000loop12390668579000000loop135402152647000000loop144702132871000000loop15640212651000000

merged:表示一次来自于合并的写/读请求,一般系统会把多个连接/邻近的读/写请求合并到一起来操作。

5)、vmstat -a 显示活跃内存与非活跃内存

使用-a选项显示活跃和非活跃内存时,所显示的内容除增加inact和active外,其他显示内容与例子1相同。

linuxidc@linuxidc:~/桌面/www.linuxidc.com$vmstat-aprocs-----------memory-------------swap-------io-----system--------cpu-----rb交换空闲不活动活动sisobiboincsussyidwast40099324408308104688800722955153119800

Linux vmstat命令实际操作介绍Linux vmstat命令实际操作介绍
6)、vmstat -f 查看系统已经被fork多少次

linuxidc@linuxidc:~/桌面/www.linuxidc.com$ vmstat -f 5100 forks

7)、vmstat -p tmpfs  查看特定磁盘设备的

linuxidc@linuxidc:~/桌面/www.linuxidc.com$vmstat-p/dev/sda1sda1readsreadsectorswritesrequestedwrites23879161780210140668056

说明: 这些信息主要来自于/proc/diskstats。 reads:         来自于这个分区的读的次数。 read sectors:     来自于这个分区的读扇区的次数。 writes:        来自于这个分区的写的次数。 requested writes:  来自于这个分区的写请求次数。

8)、vmstat -m        显示slabinfo

linuxidc@linuxidc:~/桌面/www.linuxidc.com$ sudo vmstat -m

以上是“vmstat命令怎么用”这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注亿速云行业资讯频道!