性能监控和优化
top
free
vmstat
用来统计虚拟内存的使用情况,这边涉及到linux物理内存和虚拟内存的知识点,其实之前我们也提到过,虚拟内存即交换区
option参数
-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版本信息
使用实例
$vmstat 5 6 在docker上进行试验,在6秒内采集5次数据
说明
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时间
需要关注的指标
如果 r经常大于 4 ,且id经常少于40,表示cpu的负荷很重
如果bi,bo 长期不等于0,表示内存不足
如果disk 经常不等于0, 且在 b中的队列 大于3, 表示 io性能不好