Linux iostat命令使用

Linux系统出现了性能问题,通常咱们能够经过top、iostat、free、vmstat等命令 来查看初步定位问题。其中iostat能够给咱们提供丰富的IO状态数据。ios

1. 基本使用express

$iostat -d -k 1 10并发

参数 -d 表示,显示设备(磁盘)使用状态;-k某些使用block为单位的列强制使用Kilobytes为单位;1 10表示,数据显示每隔1秒刷新一次,共显示10次。性能

$iostat-d -k 110
Device: tps kB_read/s kB_wrtn/s kB_read kB_wrtn
sda 39.2921.141.4444133980729990031
sda1 0.000.000.001623523
sda2 1.321.434.542983427394827104
sda3 6.300.8524.9517816289520725244
sda5 0.850.463.40954350370970116
sda6 0.000.000.00550236
sda7 0.000.000.004060
sda8 0.000.000.004060
sda9 0.000.000.004060
sda10 60.6818.3571.433830022631490928140

Device: tps kB_read/s kB_wrtn/s kB_read kB_wrtn
sda 327.555159.18102.045056100
sda1 0.000.000.0000

ps:该设备每秒的传输次数(Indicate the number of transfers per second that were issued to the device.)。“一次传输”意思是“一次I/O请求”。多个逻辑请求可能会被合并为“一次I/O请求”。“一次传输”请求的大小是未知的。code

kB_read/s:每秒从设备(drive expressed)读取的数据量;kB_wrtn/s:每秒向设备(drive expressed)写入的数据量;kB_read:读取的总数据量;kB_wrtn:写入 的总数量数据量;这些单位都为Kilobytes。requests

上面的例子中,咱们能够看到磁盘sda以及它的各个分区的统计数据,当时统计的磁盘总TPS是39.29,下面是各个分区的TPS。(由于是瞬间 值,因此总TPS并不严格等于各个分区TPS的总和)it

2. -x 参数io

使用-x参数咱们能够得到更多统计信息。sed

iostat -d -x -k 110Device: rrqm/s wrqm/s r/s w/s rsec/s wsec/s rkB/s wkB/s avgrq-sz avgqu-sz await svctm %util
sda 1.5628.317.8031.4942.512.9221.261.461.160.030.792.6210.28Device: rrqm/s wrqm/s r/s w/s rsec/s wsec/s rkB/s wkB/s avgrq-sz avgqu-sz await svctm %util
sda 2.0020.00381.007.0012320.00216.006160.00108.0032.311.754.502.1784.20

rrqm/s:每秒这个设备相关的读取请求有多少被Merge了(当系统调用须要读取数据的 时候,VFS将请求发到各个FS,若是FS发现不一样的读取请求读取的是相同Block的数据,FS会将这个请求合并Merge);wrqm/s:每秒这个 设备相关的写入请求有多少被Merge了。request

rsec/s:每秒读取的扇区数;wsec/: 每秒写入的扇区数。r/s:The number of read requests that were issued to the device per second;w/s:The number of write requests that were issued to the device per second;

await:每个IO请求的处理的平均时间(单位是ms)。这里能够理解为IO的响应时 间,通常地系统IO响应时间应该低于5ms,若是大于10ms就比较大了。

%util:在统计时间内全部处理IO时间,除以总共统计时间。例如,若是统计间隔1秒,该 设备有0.8秒在处理IO,而0.2秒闲置,那么该设备的%util = 0.8/1 = 80%,因此该参数暗示了设备的繁忙程度。通常地,若是该参数是100%表示设备已经接近满负荷运行了(固然若是是多磁盘,即便%util是100%,因 为磁盘的并发能力,因此磁盘使用未必就到了瓶颈)。

3. -c 参数

iostat还能够用来获取cpu部分状态值:

iostat -c 110
avg-cpu: %user%nice%sys%iowait%idle1.980.000.3511.4586.22
avg-cpu: %user%nice%sys%iowait%idle1.620.000.2534.4663.67

4. 常见用法

$iostat -d -k 1 10 #查看TPS和吞吐量信息
iostat -d -x -k 1 10 #查看设备使用率(%util)、响应时间(await)
iostat -c 1 10 #查看cpu状态

5. 实例分析

$iostat -d -k 1 |grep sda10
Device: tps kB_read/s kB_wrtn/s kB_read kB_wrtn
sda10 60.7218.9571.533956376471493241908
sda10 299.024266.67129.414352132
sda10 483.844589.904117.1745444076
sda10 218.003360.00100.003360100
sda10 546.008784.00124.008784124
sda10 827.0013232.00136.0013232136
上面看到,磁盘每秒传输次数平均约400;每秒磁盘读取约5MB,写入约1MB。

iostat -d -x -k 1Device: rrqm/s wrqm/s r/s w/s rsec/s wsec/s rkB/s wkB/s avgrq-sz avgqu-sz await svctm %util
sda 1.5628.317.8431.5043.653.1621.821.581.190.030.802.6110.29
sda 1.9824.75419.806.9313465.35253.476732.67126.7332.152.004.702.0085.25
sda 3.0641.84444.9054.0814204.082048.987102.041024.4932.572.104.211.8592.24

能够看到磁盘的平均响应时间<5ms,磁盘使用率>80。磁盘响应正常,可是已经很繁忙了。

相关文章
相关标签/搜索