当前位置:首页 > 运维 > 正文内容

linux中如何查看系统io使用情况

phpmianshi5年前 (2016-04-18)运维226

linux中查看IO的方法主要有下面几种方法:


1. top   %wa    的含义是等待输入输出的CPU时间百分比,这个数字越高说明越多的CPU资源在等待I/O权限

top - 18:38:17 up 13:37,  2 users,  load average: 0.18, 0.35, 0.27
Tasks: 161 total,   1 running, 160 sleeping,   0 stopped,   0 zombie
Cpu(s): 13.8%us,  4.0%sy,  0.0%ni, 80.4%id,  1.3%wa,  0.0%hi,  0.3%si,  0.0%st
Mem:   3922696k total,  3681552k used,   241144k free,   378892k buffers
Swap:  2097148k total,    84536k used,  2012612k free,  1126236k cached


2. top可以查看一个整体的io情况,但是没法定位哪个磁盘出现io问题了,我们可以结合iostat查看


语法:iostat [ options ] [ <interval> [ <count> ] ]   interval 采样间隔  count采样次数  I/O statistics(输入/输出统计)的缩写

options 说明:

-c CPU的使用情况,单独显示avg-cpu部分

-d 磁盘的使用情况,单独显示Device部分

-x  更详细的io统计信息 在分析io瓶颈时,一般都会开启-x选项

-k  以kB为单位显示

-m  以mB为单位显示

注意,第1次采样信息与单独执行iostat的效果一样,为从系统开机到当前执行时刻的统计信息。


iostat用于输出CPU和磁盘I/O相关的统计信息,单独执行iostat,显示的结果为从系统开机到当前执行时刻的统计信息

avg-cpu:  %user   %nice %system %iowait  %steal   %idle
          11.28    0.00    2.26    0.75    0.00   85.71

Device:   rrqm/s wrqm/s  r/s  w/s    rkB/s  wkB/s avgrq-sz avgqu-sz   await r_await w_await svctm  %util
vda     0.00  0.00   0.00  0.00    0.00  0.00  0.00   0.00    0.00  0.00   0.00  0.00   0.00
vdb     0.00  0.00   2.00  0.00    8.00  0.00  8.00   0.04     19.00  19.00  0.00  19.00   3.80
scd0     0.00  0.00   0.00  0.00    0.00  0.00  0.00   0.00    0.00  0.00   0.00  0.00   0.00


选项说明
%userCPU在用户态执行进程的时间百分比。
%niceCPU在用户态模式下,用于nice操作,所占用CPU总时间的百分比
%systemCPU处在内核态执行进程的时间百分比
%iowaitCPU用于等待I/O操作占用CPU总时间的百分比
%steal管理程序(hypervisor)为另一个虚拟进程提供服务而等待虚拟CPU的百分比
%idleCPU空闲时间百分比

1. 若 %iowait 的值过高,表示硬盘存在I/O瓶颈 
2. 若 %idle 的值高但系统响应慢时,有可能是CPU等待分配内存,此时应加大内存容量 

3. 若 %idle 的值持续低于1,则系统的CPU处理能力相对较低,表明系统中最需要解决的资源是 CPU


选项说明
rrqm/s每秒对该设备的读请求被合并次数,文件系统会对读取同块(block)的请求进行合并
wrqm/s每秒对该设备的写请求被合并次数
r/s每秒完成的读次数
w/s每秒完成的写次数
rkB/s每秒读数据量(kB为单位)
wkB/s每秒写数据量(kB为单位)
avgrq-sz平均每次IO操作的数据量(扇区数为单位)
avgqu-sz平均等待处理的IO请求队列长度
await

平均每次IO请求等待时间(包括等待时间和处理时间,毫秒为单位)

 一般的系统IO响应时间应该低于5ms,如果大于10ms就比较大了

svctm

平均每次IO请求的处理时间(毫秒为单位)

如果svctm的值与await很接近,表示几乎没有I/O等待,磁盘性能很好

如果await的值远高于svctm的值,则表示I/O队列等待太长,系统上运行的应用程序将变慢。

%util

采用周期内用于IO操作的时间比率,即IO队列非空的时间比率

例如,如果统计间隔1秒,该设备有0.8秒在处理IO,而0.2秒闲置,那么该设备的%util = 0.8/1 = 80%

所以该参数暗示了设备的繁忙程度。一般地,如果该参数是100%表示设备已经接近满负荷运行了

平时我们主要关注这三个参数:await  svctm $util


3.我们更关注的是哪个进程io出现了问题,这时候使用iotop查找

iotop

Actual DISK READ:       7.82 K/s | Actual DISK WRITE:      15.64 K/s
  TID  PRIO  USER     DISK READ  DISK WRITE  SWAPIN     IO>    COMMAND          
 3981 be/4 root        7.82 K/s    0.00 B/s  0.00 %  0.21 % YDService
29094 be/4 www         0.00 B/s   19.55 K/s  0.00 %  0.00 % nginx: wo~er process
29095 be/4 www         0.00 B/s   31.27 K/s  0.00 %  0.00 % nginx: wo~er process


4.查找哪个文件引起的I/Owait    


lsof -p 29093


可以查看哪些文件正在读写。


更多lsof用法参考:https://phpmianshi.com/?id=103


5.查看历史io情况  比如查看11号的


sar -b -f  /var/log/sa11
sar -u -f /var/log/sa11
sar -d -f /var/log/sa11


更多sar用法参考:https://phpmianshi.com/?id=107


版权声明:本文由PHP面试资料网发布,如需转载请注明出处。
分享给朋友:

相关文章

linux中nf_conntrack table full dropping packet问题处理

概述:在日常的服务器运维过程中,发现某段时间 /var/log/messages日志报错nf_conntrack:table full,drop packet简介:nf_connt...

linux中sed用法读这一篇就够了

1.概念sed是一种行编辑器,它一次处理一行内容。处理时,把 当前处理的行存储在临时缓冲区中,称为“模式空间”(pattern space),接着用sed命令处理缓冲区中的内容,处理完成后,把缓冲区的...

linux中Cannot assign requested address的问题处理

问题描述:最近系统报警有类型如下错误:Cannot assign requested address  主要是连接mysql时产生的错误。分析原因:客户端与服务端每建立一个连接,客户端一侧都...

守护进程详解及其代码实现

1、概念理解:守护进程(Daemon)是运行在后台的一种特殊进程,也称为精灵进程。是生存期较长的一种进程,常常在系统自举时启动,仅在系统关闭时终止。没有控制终端,仅仅在后台运行,Linux有很多守护进...

jmeter压测实战

jmeter压测实战

下载安装下载JDK  : https://download.oracle.com/otn-pub/java/jdk/15.0.2+7/0d1cfde4252546c6931946de8db4...

linux中多文件按行拼接整合命令paste

概念Linux下的paste命令主要用于从多个文件(包括标准输入)中读取内容,将每个文件的对应行用指定分隔符(默认tab制表符)拼接起来并打印到标准输出,我们可以使用重定向命令“>”将输出结果保...

发表评论

访客

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。