关于我们

质量为本、客户为根、勇于拼搏、务实创新

< 返回新闻公共列表

Linux中虚拟内存查看命令vmstat的过程

发布时间:2021-09-01 11:17:49

本篇内容主要讲解“Linux中虚拟内存查看命令vmstat的过程”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Linux中虚拟内存查看命令vmstat的过程”吧!

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的过程”有了更深的了解,不妨来实际操作一番吧!这里是昊之云网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!


/template/Home/Zkeys/PC/Static