linux命令性能监控及优化

性能监控和优化

top

top

free

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性能不好

显示 Gitment 评论