阿里云-云小站(无限量代金券发放中)
【腾讯云】云服务器、云数据库、COS、CDN、短信等热卖云产品特惠抢购

Linux系统负载监控-vmstat

121次阅读
没有评论

共计 2787 个字符,预计需要花费 7 分钟才能阅读完成。

查看系统负载
常用命令,其中 1 表示 1 秒刷新一次,- S 表示单位,M 表示 MB
vmstat 1 -S M

简介
    vmstat 是一个十分有用的 Linux 系统监控工具,使用 vmstat 命令可以得到关于进程、内存、内存分页、堵塞 IO、traps 及 CPU 活动的信息。

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

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

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

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

vmstat 的例子
例子 1
每一秒输出一条记录,单位是 MB
[piaohailin@chinaso ~]$ vmstat 1 -S m
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  4449    874  30468    0    0    0    13    0    0  1  0 99  0  0
 2  0      0  4449    874  30468    0    0    0    0 2242 2677 10  0 90  0  0
 4  0      0  4449    874  30468    0    0    0    0 2869 3007 12  0 88  0  0
属性说明
字段说明:
Procs(进程):
r: 运行队列中进程数量
b: 等待 IO 的进程数量
Memory(内存):
swpd: 使用虚拟内存大小
free: 可用内存大小
buff: 用作缓冲的内存大小
cache: 用作缓存的内存大小
Swap:
si: 每秒从交换区写到内存的大小
so: 每秒写入交换区的内存大小
IO:(现在的 Linux 版本块的大小为 1024bytes)
bi: 每秒读取的块数
bo: 每秒写入的块数
系统:
in: 每秒中断数,包括时钟中断。
cs: 每秒上下文切换数。
CPU(以百分比表示):
us: 用户进程执行时间(user time)
sy: 系统进程执行时间(system time)
id: 空闲时间(包括 IO 等待时间)
wa: 等待 IO 时间

例子 2
显示活跃和非活跃内存,每 1 秒输出一行
[piaohailin@chinaso ~]$ vmstat -a 1
procs ———–memory———- —swap– —–io—- –system– —–cpu—–
 r  b  swpd  free  inact active  si  so    bi    bo  in  cs us sy id wa st
 0  0      0 4343984 15324536 44528424    0    0    0    13    0    0  1  0 99  0  0
 0  0      0 4343620 15324536 44528572    0    0    0    0  797 1537  0  0 100  0  0
 0  0      0 4343744 15324536 44528348    0    0    0    0  627 1451  0  0 100  0  0
 4  0      0 4343868 15324536 44528348    0    0    0    0 1022 1823  2  0 98  0  0
 3  0      0 4343992 15324536 44528352    0    0    0    84 2777 4422 13  0 87  0  0
 1  0      0 4344116 15324540 44528364    0    0    0    0 2409 3428 10  0 90  0  0
属性说明
Memory(内存):
inact: 非活跃内存大小(当使用 - a 选项时显示)
active: 活跃的内存大小(当使用 - a 选项时显示)

 

vmstat 的用法
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]

-a:显示活跃和非活跃内存
-f:显示从系统启动至今的 fork 数量。
-m:显示 slabinfo
-n:只在开始时显示一次各字段名称。
-s:显示内存相关统计信息及多种系统活动数量。
delay:刷新时间间隔。如果不指定,只显示一条结果。
count:刷新次数。如果不指定刷新次数,但指定了刷新时间间隔,这时刷新次数为无穷。
-d:显示磁盘相关统计信息。
-p:显示指定磁盘分区统计信息
-S:使用指定单位显示。参数有 k、K、m、M,分别代表 1000、1024、1000000、1048576 字节(byte)。默认单位为 K(1024 bytes)
-V:显示 vmstat 版本信息。

Linux vmstat 命令详解 http://www.linuxidc.com/Linux/2013-03/80983.htm

Linux 下 vmstat 显示结果详解 http://www.linuxidc.com/Linux/2013-01/77497.htm

Linux 监控工具之 vmstat 详解 http://www.linuxidc.com/Linux/2012-09/71295.htm

Linux vmstat 命令实战详解 http://www.linuxidc.com/Linux/2012-06/61771.htm

Linux vmstat 监控系统负载 http://www.linuxidc.com/Linux/2012-01/51340.htm

vmstat 命令详解——Linux 性能分析 http://www.linuxidc.com/Linux/2014-06/102884.htm

正文完
星哥说事-微信公众号
post-qrcode
 0
星锅
版权声明:本站原创文章,由 星锅 于2022-01-20发表,共计2787字。
转载说明:除特殊说明外本站文章皆由CC-4.0协议发布,转载请注明出处。
【腾讯云】推广者专属福利,新客户无门槛领取总价值高达2860元代金券,每种代金券限量500张,先到先得。
阿里云-最新活动爆款每日限量供应
评论(没有评论)
验证码
【腾讯云】云服务器、云数据库、COS、CDN、短信等云产品特惠热卖中