Vmstat 命令详解

目录

一、Vmstat命令 概述
1.1 物理内存和虚拟内存区别
1.1.1 物理内存
1.1.2 虚拟内存
1.2 vmstat 命令语法
1.2.1 格式
1.2.2 命令参数
二、 vmstat 示例
2.1 显示虚拟内存使用情况
2.1.1 查看
2.1.2 表示在1秒时间内进行2次采样
2.1.3 指定的MB 单位输出结果
2.2 显示活跃和非活跃内存
2.3 查看系统已经fork了多少次
2.4 查看内存使用的详细信息
2.5 查看磁盘的读/写
2.6 查看/dev/sda1磁盘的读/写
2.7 查看系统的slab信息
三、压力测试,观察虚拟内存的变化

一、Vmstat命令 概述

vmstat是Virtual Meomory Statistics(虚拟内存统计)的缩写,可对操作系统的虚拟内存、进程、CPU活动进行监控。
它是对系统的整体情况进行统计,不足之处是无法对某个进程进行深入分析。
vmstat 工具提供了一种低开销的系统性能观察方式。因为 vmstat 本身就是低开销工具,在非常高负荷的服务器上,需要查看并监控系统的健康情况,在控制窗口还是能够使用vmstat 输出结果。
在学习vmstat命令前,我们先了解一下Linux系统中关于物理内存和虚拟内存相关信息。

1.1 物理内存和虚拟内存区别

Linux系统的内存分为物理内存和虚拟内存两种。物理内存是真实的,也就是物理内存条上的内存。而虚拟内存则是采用硬盘空间补充物理内存,将暂时不使用的内存页写到硬盘上以腾出更多的物理内存让有需要的进程使用。当这些已被腾出的内存页需要再次使用时才从硬盘(虚拟内存)中读回内存。这一切对于用户来说是透明的。通常对Linux系统来说,虚拟内存就是swap分区。

1.1.1 物理内存

物理内存就是系统硬件提供的内存大小,是真正的内存,相对于物理内存,在linux下还有一个虚拟内存的概念,虚拟内存就是为了满足物理内存的不足而提出的策略,它是利用磁盘空间虚拟出的一块逻辑内存,用作虚拟内存的磁盘空间被称为交换空间(Swap Space)。作为物理内存的扩展linux会在物理内存不足时,使用交换分区的虚拟内存,更详细的说,就是内核会将暂时不用的内存块信息写到交换空间,这样以来,物理内存得到了释放,这块内存就可以用于其它目的,当需要用到原始的内容时,这些信息会被重新从交换空间读入物理内存。

linux的内存管理采取的是分页存取机制,为了保证物理内存能得到充分的利用,内核会在适当的时候将物理内存中不经常使用的数据块自动交换到虚拟内存中,而将经常使用的信息保留到物理内存。

要深入了解linux内存运行机制,需要知道下面提到的几个方面:
首先,Linux系统会不时的进行页面交换操作,以保持尽可能多的空闲物理内存,即使并没有什么事情需要内存,Linux也会交换出暂时不用的内存页面。这可以避免等待交换所需的时间。
其次,linux进行页面交换是有条件的,不是所有页面在不用时都交换到虚拟内存,linux内核根据”最近最经常使用“算法,仅仅将一些不经常使用的页面文件交换到虚拟内存,有时我们会看到这么一个现象:linux物理内存还有很多,但是交换空间也使用了很多。其实,这并不奇怪,例如,一个占用很大内存的进程运行时,需要耗费很多内存资源,此时就会有一些不常用页面文件被交换到虚拟内存中,但后来这个占用很多内存资源的进程结束并释放了很多内存时,刚才被交换出去的页面文件并不会自动的交换进物理内存,除非有这个必要,那么此刻系统物理内存就会空闲很多,同时交换空间也在被使用,就出现了刚才所说的现象了。关于这点,不用担心什么,只要知道是怎么一回事就可以了。

最后,交换空间的页面在使用时会首先被交换到物理内存,如果此时没有足够的物理内存来容纳这些页面,它们又会被马上交换出去,如此以来,虚拟内存中可能没有足够空间来存储这些交换页面,最终会导致linux出现假死机、服务异常等问题,linux虽然可以在一段时间内自行恢复,但是恢复后的系统已经基本不可用了。
因此,合理规划和设计linux内存的使用,是非常重要的。

1.1.2 虚拟内存

在系统中运行的每个进程都需要使用到内存,但不是每个进程都需要每时每刻使用系统分配的内存空间。当系统运行所需内存超过实际的物理内存,内核会释放某些进程所占用但未使用的部分或所有物理内存,将这部分资料存储在磁盘上直到进程下一次调用,并将释放出的内存提供给有需要的进程使用。

在Linux内存管理中,主要是通过“调页Paging”和“交换Swapping”来完成上述的内存调度。调页算法是将内存中最近不常使用的页面换到磁盘上,把活动页面保留在内存中供进程使用。交换技术是将整个进程,而不是部分页面,全部交换到磁盘上。

分页(Page)写入磁盘的过程被称作Page-Out,分页(Page)从磁盘重新回到内存的过程被称作Page-In。当内核需要一个分页时,但发现此分页不在物理内存中(因为已经被Page-Out了),此时就发生了分页错误(Page Fault)。

当系统内核发现可运行内存变少时,就会通过Page-Out来释放一部分物理内存。经管Page-Out不是经常发生,但是如果Page-out频繁不断的发生,直到当内核管理分页的时间超过运行程式的时间时,系统效能会急剧下降。这时的系统已经运行非常慢或进入暂停状态,这种状态亦被称作thrashing。

1.2 vmstat 命令语法

用来显示虚拟内存的信息

1.2.1 格式
vmstat [-a] [-n] [-S unit] [delay [ count]]
vmstat [-s] [-n] [-S unit]
vmstat [-m] [-n] [delay [ count]]
vmstat [-d] [-n] [delay [ count]]
vmstat [-p disk partition] [-n] [delay [ count]]
vmstat [-f]
vmstat [-V]
1.2.2 命令参数

在这里插入图片描述

二、vmstat 示例

2.1 显示虚拟内存使用情况

2.1.1 查看
# vmstat
procs -----------memory---------- ---swap-- -----io---- -system-- ------cpu-----
 r  b   swpd   free   buff  cache   si   so    bi    bo   in   cs us sy id wa st
 1  0      0 442868      0 62842692    0    0   683     0    2    1  3  1 96  1  0

字段说明:

procs(进程):
r: 运行队列中进程数量
b: 等待IO的进程数量
Memory(内存):
swpd: 使用虚拟内存大小
free: 可用内存大小
buff: 用作缓冲的内存大小
cache:用作缓存的内存大小
Swap(交换空间内存):
si: 每秒从交换区写到内存的大小
so: 每秒写入交换区的内存大小
IO:(现在的Linux版本块的大小为1024bytes)
bi: 每秒读取的块数
bo: 每秒写入的块数
system:(系统信息)
in: 每秒中断数,包括时钟中断。
cs: 每秒上下文切换数
CPU(以百分比表示):
us: 用户进程执行时间(user time)
sy: 系统进程执行时间(system time)
id: 空闲时间(包括IO等待时间),中央处理器的空闲时间 。以百分比表示。
wa: 等待IO时间
st: 被虚拟机使用的 CPU 时间的百分比

空闲 CPU时间,一般来说,id + us + sy = 100,一般我认为id是空闲CPU使用率,us是用户CPU使用率,sy是系统CPU使用率。

备注: 如果 r经常大于 4,且id经常少于40,表示cpu的负荷很重。如果pi,po 长期不等于0,表示内存不足。如果disk 经常不等于0, 且在 b中的队列 大于3, 表示 io性能不好。Linux在具有高稳定性、可靠性的同时,具有很好的可伸缩性和扩展性,能够针对不同的应用和硬件环境调整,优化出满足当前应用需要的最佳性能。因此企业在维护Linux系统、进行系统调优时,了解系统性能分析工具是至关重要的。

(1)如果在processes中运行的序列(process r)是连续的大于在系统中的CPU的个数表示系统现在运行比较慢,有多数的进程等待CPU。

(2)如果r的输出数大于系统中可用CPU个数的4倍的话,则系统面临着CPU短缺的问题,或者是CPU的速率过低,系统中有多数的进程在等待CPU,造成系统中进程运行过慢。

(3)如果空闲时间(cpu id)持续为0并且系统时间(cpu sy)是用户时间的两倍(cpu us)系统则面临着CPU资源的短缺。

当发生以上问题的时候请先调整应用程序对CPU的占用情况.使得应用程序能够更有效的使用CPU.同时可以考虑增加更多的CPU. 关于CPU的使用情况还可以结合mpstat, ps aux top prstat –a等等一些相应的命令来综合考虑关于具体的CPU的使用情况,和那些进程在占用大量的CPU时间.一般情况下,应用程序的问题会比较大一些.比如一些sql语句不合理等等都会造成这样的现象.

2.1.2 表示在1秒时间内进行2次采样

将得到一个数据汇总他能够反映真正的系统情况

# vmstat 1 2
procs -----------memory---------- ---swap-- -----io---- -system-- ------cpu-----
 r  b   swpd   free   buff  cache   si   so    bi    bo   in   cs us sy id wa st
 2  0      0 451956      0 63036692    0    0   682     0    0    2  3  1 96  1  0
 3  0      0 451244      0 63036956    0    0   956     0 5861 5589  7  3 89  0  0
2.1.3 指定的MB 单位输出结果
# vmstat -S M 1 2
procs -----------memory---------- ---swap-- -----io---- -system-- ------cpu-----
 r  b   swpd   free   buff  cache   si   so    bi    bo   in   cs us sy id wa st
 2  0      0    415      0  61726    0    0   573     0    1    1  5  1 93  1  0
 2  0      0    414      0  61727    0    0   596     0 5015 4640  8  3 89  0  0

2.2 显示活跃和非活跃内存

# vmstat -a 2 5
procs -----------memory---------- ---swap-- -----io---- -system-- ------cpu-----
 r  b   swpd   free  inact active   si   so    bi    bo   in   cs us sy id wa st
 2  0      0 399928 25124928 37083544    0    0   682     0    0    2  3  1 96  1  0
 2  1      0 398200 25126312 37083928    0    0  1302     0 6026 6025  7  3 89  0  0
 4  0      0 397176 25127380 37083872    0    0  1064     0 5879 5825  7  3 89  1  0
 2  0      0 395196 25129592 37083888    0    0  1452     0 5851 5682  7  3 89  0  0
 1  0      0 479244 25062888 37067092    0    0  1118     0 6125 6128  8  4 89  0  0

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

字段说明:

Memory(内存):
inact: 非活跃内存大小(当使用-a选项时显示)
active: 活跃的内存大小(当使用-a选项时显示)

2.3 查看系统已经fork了多少次

在Linux中fork函数是非常重要的函数,它的作用是从已经存在的进程中创建一个子进程,而原进程称为父进程。

# vmstat -f
      1522088 forks
# vmstat -f
      1522138 forks

说明:这个数据是从/proc/stat中的processes字段里取得。

2.4 查看内存使用的详细信息

# vmstat -s
     65935764 K total memory
      2601176 K used memory
     38309332 K active memory
     23759264 K inactive memory
       441796 K free memory
            0 K buffer memory
     62892792 K swap cache
     67108860 K total swap
            0 K used swap
     67108860 K free swap
    121519833 non-nice user cpu ticks
          393 nice user cpu ticks
     35445478 system cpu ticks
   2450752541 idle cpu ticks
     36672077 IO-wait cpu ticks
            0 IRQ cpu ticks
       740578 softirq cpu ticks
            0 stolen cpu ticks
  15167080525 pages paged in
            0 pages paged out
            0 pages swapped in
            8 pages swapped out
   1999102221 interrupts
   2110995102 CPU context switches
   1717464459 boot time
      1522206 forks

说明:这些信息的分别来自于/proc/meminfo,/proc/stat和/proc/vmstat。

以指定的 MB 单位输出各事件计数器和内存的统计信息
# vmstat -s -S M
        64390 M total memory
         2528 M used memory
        37384 M active memory
        23203 M inactive memory
          461 M free memory
            0 M buffer memory
        61400 M swap cache
        65535 M total swap
            0 M used swap
        65535 M free swap
    121532769 non-nice user cpu ticks
          393 nice user cpu ticks
     35450617 system cpu ticks
   2450887927 idle cpu ticks
     36672686 IO-wait cpu ticks
            0 IRQ cpu ticks
       740611 softirq cpu ticks
            0 stolen cpu ticks
  15167181871 pages paged in
            0 pages paged out
            0 pages swapped in
            8 pages swapped out
   1999653140 interrupts
   2111501192 CPU context switches
   1717464459 boot time
      1522295 forks

2.5 查看磁盘的读/写

# vmstat -d
isk- ------------reads------------ ------------writes----------- -----IO------
       total merged sectors      ms  total merged sectors      ms    cur    sec
sdd   16819625   3016 6342189233 81427611 6164098   8562 2498204155 211651305      0  20134
sdb   192789344  37251 83289544094 1023942949 56474322 221884 24814218206 2634486481      0 141549
sdc   8887795   5401 4103541204 51694206 3501627    248 1875583280 110413270      0  13305
sda   54318287   2175 739351121 28895360 55335309  47551 1146468556 91913376      0 101795
sr0        0      0       0       0      0      0       0       0      0      0
dm-0  167233731      0 93735272035 666861775 58279777      0 29188005641 1517135104      0 136322

说明:这些信息主要来自于/proc/diskstats 。

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

reads(读):
 
             total:     成功读取的总数
             merged:    分组读取(产生一个 IO)
             sectors:   成功读取的扇区数
             ms:        读取花费的毫秒
writes(写):
 
             total:      成功写入的总数
             merged:     分组写入(产生一个 IO)
             sectors:    成功写入的扇区数
             ms:         写花费的毫秒
IO
 
     cur:    正在进行的IO
     sec:      IO花费的秒数

2.6 查看/dev/sda1磁盘的读/写

# vmstat -p /dev/sda1
sda1          reads   read sectors  writes    requested writes
                  95      14686         18       4194

说明:这些信息主要来自于/proc/diskstats。

reads:来自于这个分区的读的次数。
read sectors:来自于这个分区的读扇区的次数。
writes:来自于这个分区的写的次数。
requested writes:来自于这个分区的写请求次数。

2.7 查看系统的slab信息

# vmstat -m
Cache                       Num  Total   Size  Pages
nfs_direct_cache              0      0    360     45
nfs_read_data               850   1008    896     36
nfs_inode_cache            2490   2490   1088     30
fscache_cookie_jar          138    138     88     46
AF_VSOCK                     26     26   1216     26
rpc_inode_cache             368    368    704     46
kcopyd_job                    0      0   3312      9
dm_uevent                     0      0   2632     12
xfs_dqtrx                     0      0    528     62
xfs_rui_item                  0      0    672     48
xfs_rud_item                  0      0    152     53
xfs_ili                    9600   9600    168     48
xfs_inode                  5065   9554    960     34
xfs_efd_item               2496   2574    416     39
xfs_buf_item               1320   1320    248     66
xfs_da_state               1088   1088    480     68
xfs_btree_cur              1120   1120    232     70
xfs_log_ticket             4620   4620    184     44
bio-2                      4641   4641    320     51
scsi_sense_cache           3776   3776    128     64
ip6-frags                     0      0    208     39
PINGv6                        0      0   1152     28
RAWv6                       280    280   1152     28
UDPv6                       400    400   1280     25
tw_sock_TCPv6                 0      0    248     66
request_sock_TCPv6            0      0    312     52
TCPv6                       240    240   2176     15
search                        0      0    616     53
Cache                       Num  Total   Size  Pages
sgpool-128                  312    352   4096      8
cfq_io_cq                     0      0    120     68
mqueue_inode_cache           34     34    960     34
userfaultfd_ctx_cache         0      0    192     42
dio                         816    816    640     51
pid_namespace                 0      0   2232     14
posix_timers_cache            0      0    240     68
ip4-frags                  4070   4070    216     37
xfrm_dst_cache                0      0    448     36
PING                          0      0    960     34
RAW                         544    544    960     34
tw_sock_TCP                 594    594    248     66
request_sock_TCP            468    468    312     52
TCP                         737    768   2048     16
hugetlbfs_inode_cache        98     98    664     49
dquot                         0      0    256     64
dax_cache                    84     84    768     42
request_queue                60     60   2176     15
blkdev_ioc                  624    624    104     39
biovec-max                  177    204   8192      4
biovec-128                  816    896   2048     16
biovec-64                  1155   1216   1024     32
user_namespace                0      0    488     67
dmaengine-unmap-256          15     15   2112     15
dmaengine-unmap-128         480    480   1088     30
dmaengine-unmap-16         1050   1050    192     42
dmaengine-unmap-2          1024   1024     64     64
sock_inode_cache           1794   1794    704     46
Cache                       Num  Total   Size  Pages
skbuff_fclone_cache        2240   2240    512     64
skbuff_head_cache          8703   8960    256     64
file_lock_cache            5960   5960    200     40
fsnotify_mark_connector    2720   2720     24    170
net_namespace                 5      5   5888      5
shmem_inode_cache          2350   2350    712     46
dtrace_task_cache          4664  10432    128     64
task_delay_info            1581   1581     80     51
taskstats                   490    490    328     49
proc_inode_cache           5516   5616    680     48
sigqueue                    816    816    160     51
bdev_cache                  429    429    832     39
kernfs_node_cache         44640  44640    136     60
mnt_cache                  3044   3192    384     42
inode_cache               19297  25387    608     53
dentry                    30513  36372    192     42
names_cache                 136    136   4096      8
iint_cache                    0      0     80     51
avc_xperms_data            2048   2048     32    128
selinux_file_security      4096   4096     16    256
buffer_head              857727 857727    104     39
vm_area_struct            27084  27084    216     37
mm_struct                   883    900   2176     15
files_cache                1242   1242    704     46
signal_cache               1475   1620   1088     30
sighand_cache              1140   1140   2112     15
task_struct                 663    690   5760      5
cred_jar                   3612   3612    192     42
Cache                       Num  Total   Size  Pages
Acpi-Operand              11984  11984     72     56
Acpi-Parse                10731  10731     56     73
Acpi-State                  969    969     80     51
Acpi-Namespace            31722  31722     40    102
anon_vma_chain            18444  19712     64     64
anon_vma                  13060  13248     88     46
pid                        1344   1344    128     64
numa_policy                 186    186    264     62
trace_event_file           2116   2116     88     46
ftrace_event_field         3910   3910     48     85
pool_workqueue            13625  16896    256     64
radix_tree_node          2321036 2534896    584     56
task_group                  839   1150    704     46
dma-kmalloc-8192              0      0   8192      4
dma-kmalloc-4096              0      0   4096      8
dma-kmalloc-2048              0      0   2048     16
dma-kmalloc-1024              0      0   1024     32
dma-kmalloc-512              64     64    512     64
dma-kmalloc-256               0      0    256     64
dma-kmalloc-128               0      0    128     64
dma-kmalloc-64                0      0     64     64
dma-kmalloc-32                0      0     32    128
dma-kmalloc-16                0      0     16    256
dma-kmalloc-8                 0      0      8    512
dma-kmalloc-192               0      0    192     42
dma-kmalloc-96                0      0     96     42
kmalloc-8192                159    164   8192      4
kmalloc-4096                372    384   4096      8
Cache                       Num  Total   Size  Pages
kmalloc-2048               2350   2432   2048     16
kmalloc-1024               2661   3136   1024     32
kmalloc-512               50433  54528    512     64
kmalloc-256                8583   8832    256     64
kmalloc-192                5715   5922    192     42
kmalloc-128                8512   8512    128     64
kmalloc-96                 9999  13608     96     42
kmalloc-64                14501  15552     64     64
kmalloc-32                16110  20352     32    128
kmalloc-16                41006  46848     16    256
kmalloc-8                 14848  14848      8    512
kmem_cache_node             576    576     64     64
kmem_cache                  378    378    384     42

这组信息来自于/proc/slabinfo。

slab:由于内核会有许多小对象,这些对象构造销毁十分频繁,比如i-node,dentry,这些对象如果每次构建的时候就向内存要一个页(4kb),而其实只有几个字节,这样就会非常浪费,为了解决这个问题,就引入了一种新的机制来处理在同一个页框中如何分配小存储区,而slab可以对小对象进行分配,这样就不用为每一个对象分配页框,从而节省了空间,内核对一些小对象创建析构很频繁,slab对这些小对象进行缓冲,可以重复利用,减少内存分配次数。

三、压力测试,观察虚拟内存的变化

vmstat 1(每1秒执行一次,需要手动中断)

# vmstat 1
procs -----------memory---------- ---swap-- -----io---- -system-- ------cpu-----
 r  b   swpd   free   buff  cache   si   so    bi    bo   in   cs us sy id wa st
 3  0      0 404500      0 62904300    0    0   573     0    1    0  5  1 93  1  0
 3  0      0 402600      0 62905060    0    0   968     0 6873 5479 13  4 82  1  0
 2  0      0 433108      0 62908304    0    0  3964     0 5420 4964  8  4 87  1  0
 3  0      0 432520      0 62908924    0    0  1012     0 6061 5839  7  3 89  0  0
 4  0      0 432456      0 62908924    0    0   752     0 5842 5190  9  3 87  0  0
 1  0      0 430908      0 62910588    0    0  2056     0 8459 7469 12  4 84  1  0
 2  0      0 430568      0 62911008    0    0   820     0 5490 5318  7  3 89  1  0
 2  0      0 430288      0 62911252    0    0   496     0 4743 4204  9  3 88  0  0
 2  0      0 429388      0 62911644    0    0  1498     0 5535 5368  7  3 89  0  0
  1. bo写数据到磁盘的速率,bi是从磁盘读的速度
  2. dd不断的向磁盘写入数据,所以bo的值会骤然提高,而cpu的wait数值也变高,说明由于大量的IO操作,系统的瓶径出现IO设备上
  3. 由于对文件系统的写入操作,cache也从531860KB提高到了2090360KB,又由于大量的写中断调用,in的值也从83提高到915,上

使用dd命令持续写入的时候,我们使用vmstat命令查看内存的使用情况(在此之前可以调低你的运行内存,达到实验的效果)

# dd if=/dev/zero of=/1.txt bs=1G count=20
20+0 records in
20+0 records out
21474836480 bytes (21 GB) copied, 24.1394 s, 890 MB/s
  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值