iostat查看linux硬盘IO性能

rrqm/s:   每秒进行 merge 的读操作数目。即 delta(rmerge)/s
wrqm/s:  每秒进行 merge 的写操作数目。即 delta(wmerge)/s
r/s:           每秒完成的读 I/O 设备次数。即 delta(rio)/s
w/s:         每秒完成的写 I/O 设备次数。即 delta(wio)/s
rsec/s:    每秒读扇区数。即 delta(rsect)/s
wsec/s:  每秒写扇区数。即 delta(wsect)/s
rkB/s:     每秒读K字节数。是 rsect/s 的一半,因为每扇区大小为512字节。(需要计算)
wkB/s:    每秒写K字节数。是 wsect/s 的一半。(需要计算)
avgrq-sz: 平均每次设备I/O操作的数据大小 (扇区)。delta(rsect+wsect)/delta(rio+wio)
avgqu-sz:平均I/O队列长度。即 delta(aveq)/s/1000 (因为aveq的单位为毫秒)。
await:    平均每次设备I/O操作的等待时间 (毫秒)。即 delta(ruse+wuse)/delta(rio+wio)
svctm:   平均每次设备I/O操作的服务时间 (毫秒)。即 delta(use)/delta(rio+wio)
%util:      一秒中有百分之多少的时间用于 I/O 操作,或者说一秒中有多少时间 I/O 队列是非空的。即 delta(use)/s/1000 (因为use的单位为毫秒)如果 %util 接近 100%,说明产生的I/O请求太多,I/O系统已经满负荷,该磁盘
可能存在瓶颈。
idle小于70% IO压力就较大了,一般读取速度有较多的wait.
同时可以结合vmstat 查看查看b参数()和wa参数()
另外还可以参考

svctm 一般要小于 await (因为同时等待的请求的等待时间被重复计算了),svctm
的大小一般和磁盘性能有关,CPU/内存的负荷也会对其有影响,请求过多也会间接导致 svctm 的增加。await
的大小一般取决于服务时间(svctm) 以及 I/O 队列的长度和 I/O 请求的发出模式。如果 svctm 比较接近 await,说明
I/O 几乎没有等待时间;如果 await 远大于 svctm,说明 I/O
队列太长,应用得到的响应时间变慢,如果响应时间超过了用户可以容许的范围,这时可以考虑更换更快的磁盘,调整内核 elevator
算法,优化应用,或者升级 CPU。 队列长度(avgqu-sz)也可作为衡量系统 I/O 负荷的指标,但由于 avgqu-sz
是按照单位时间的平均值,所以不能反映瞬间的 I/O 洪水。

别人一个不错的例子.(I/O 系统 vs. 超市排队)

举 一个例子,我们在超市排队 checkout 时,怎么决定该去哪个交款台呢? 首当是看排的队人数,5个人总比20人要快吧?
除了数人头,我们也常常看看前面人购买的东西多少,如果前面有个采购了一星期食品的大妈,那么可以考虑换个队排了。还有就是收银员的速度了,如果碰上了连
钱都点不清楚的新手,那就有的等了。另外,时机也很重要,可能 5
分钟前还人满为患的收款台,现在已是人去楼空,这时候交款可是很爽啊,当然,前提是那过去的 5 分钟里所做的事情比排队要有意义
(不过我还没发现什么事情比排队还无聊的)。

I/O 系统也和超市排队有很多类似之处:

r/s+w/s 类似于交款人的总数 平均队列长度(avgqu-sz)类似于单位时间里平均排队人的个数
平均服务时间(svctm)类似于收银员的收款速度 平均等待时间(await)类似于平均每人的等待时间
平均I/O数据(avgrq-sz)类似于平均每人所买的东西多少 I/O 操作率 (%util)类似于收款台前有人排队的时间比例。

我们可以根据这些数据分析出 I/O 请求的模式,以及 I/O 的速度和响应时间。

下面是别人写的这个参数输出的分析
iostat -x 1
avg-cpu:  %user   %nice    %sys   %idle
16.24    0.00    4.31   79.44
Device:                rrqm/s wrqm/s   r/s   w/s      rsec/s  wsec/s    rkB/s  wkB/s    avgrq-sz avgqu-sz   await  svctm  %util
/dev/cciss/c0d0     0.00    44.90    1.02 27.55    8.16  579.59     4.08   289.80    20.57    22.35        78.21   5.00  14.29
/dev/cciss/c0d0p1 0.00    44.90     1.02 27.55    8.16  579.59     4.08   289.80    20.57    22.35        78.21   5.00  14.29
/dev/cciss/c0d0p2 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

上面的 iostat 输出表明秒有 28.57 次设备 I/O 操作: 总IO(io)/s = r/s(读) +w/s(写) =
1.02+27.55 = 28.57 (次/秒) 其中写操作占了主体 (w:r = 27:1)。

平均每次设备 I/O 操作只需要 5ms 就可以完成,但每个 I/O 请求却需要等上 78ms,为什么? 因为发出的 I/O 请求太多
(每秒钟约 29 个),假设这些请求是同时发出的,那么平均等待时间可以这样计算:

平均等待时间 = 单个 I/O 服务时间 * ( 1 + 2 + … + 请求总数-1) / 请求总数

应用到上面的例子: 平均等待时间 = 5ms * (1+2+…+28)/29 = 70ms,和 iostat 给出的78ms
的平均等待时间很接近。这反过来表明 I/O 是同时发起的。

每秒发出的 I/O 请求很多 (约 29 个),平均队列却不长 (只有 2 个 左右),这表明这 29 个请求的到来并不均匀,大部分时间
I/O 是空闲的。

一秒中有 14.29% 的时间 I/O 队列中是有请求的,也就是说,85.71% 的时间里 I/O 系统无事可做,所有 29 个 I/O
请求都在142毫秒之内处理掉了。

delta(ruse+wuse)/delta(io) = await = 78.21 => delta(ruse+wuse)/s
=78.21 * delta(io)/s = 78.21*28.57 = 2232.8,表明每秒内的I/O请求总共需要等待2232.8ms。所以平均队列长度应为 2232.8ms/1000ms = 2.23,而 iostat 给出的平均队列长度 (avgqu-sz) 却为 22.35,为什么?! 因为 iostat 中有 bug,avgqu-sz
值应为 2.23,而不是 22.35。

本文翻译至博客园(李占卫),原文链接

https://www.cnblogs.com/tommyli/p/3623284.html

iostat查看linux硬盘IO性能相关推荐

  1. linux iostat来对linux硬盘IO性能进行了解

    iostat来对linux硬盘IO性能进行了解  via 扶凯 by admin on 2/2/09 以前一直不太会用这个参数.现在认真研究了一下iostat,因为刚好有台重要的服务器压力高,所以放上 ...

  2. iostat来对linux硬盘IO性能进行了解

    转载自:扶凯[http://www.php-oa.com] 本文链接: http://www.php-oa.com/2009/02/03/iostat.html 以前一直不太会用这个参数.现在认真研究 ...

  3. 查看linux系统的性能

    查看linux系统的性能,一般可以通过free.iostat.vmstat.top等命令来查看 [root@kumu ~]# free              total       used    ...

  4. Linux 测试 IO 性能(磁盘读写速度)

    Linux 测试 IO 性能(磁盘读写速度) 这几天做MySQL性能测试,偌大一个公司,找几台性能测试机器都很纠结,终于协调到两台,IO的性能如何还不知道. 数据库属于IO密集型的应用,所以还是先评估 ...

  5. 查看linux服务器硬盘IO读写负载

    最近一台linux服务器出现异常,系统反映很慢,相应的应用程序也无法反映,而且还出现死机的情况,经过几天的观察了解,发现服务器压力很大,主要的压力来自硬盘的IO访问已经达到100% 为了方便各位和自己 ...

  6. [转]查看linux服务器硬盘IO读写负载

    最近一台linux服务器出现异常,系统反映很慢,相应的应用程序也无法反映,而且还出现死机的情况,经过几天的观察了解,发现服务器压力很大,主要的压力来自硬盘的IO访问已经达到100% 为了方便各位和自己 ...

  7. 六个方法查看linux硬盘使用状况

    六个方法查看linux硬盘使用状况 来源:考试大 [考试大,有你,也有我!] 2011年1月27日 一.sfdisk -l [root@localhost ~]# sfdisk -l Disk /de ...

  8. Linux Reader单文件版,Linux Reader(查看Linux硬盘分区)

    Linux Reader(查看Linux硬盘分区)正式版 Linux Reader(查看Linux硬盘分区)正式版是款针对Windows环境下打造的Linux分区文件工具.Linux硬盘分区查看可以直 ...

  9. linux服务器读写硬盘io,查看linux服务器硬盘IO读写负载

    今天一台Centos服务器出了问题,客户端访问非常慢,电影播放间歇性卡壳,web访问也是很慢.首先看了服务器的流量,然后从网上找了一些方法查看服务器的IO读写负载,记录下来分享: 1. 用top命令查 ...

最新文章

  1. linux运行raxml,RAxML安装
  2. lazada新手开店之后,怎样选择正确类目来发布产品?
  3. 可以对窗口函数之后再加条件_SQL 窗口函数——解决实际问题
  4. html5点击按钮出现弹窗 怎么实现_HTML5游戏开发过程中的二三事
  5. Ubuntu如何定时清理内存
  6. Linux学习笔记 (五)关机和重启命令
  7. 百度地图java批量获得经纬度_从百度地图API接口批量获取地点的经纬度
  8. 数据可视化的优势有哪些
  9. 怎样访问远程服务器文件夹,远程访问服务器文件夹
  10. 2022年第十三届蓝桥杯省赛--难度评价
  11. lazarus编译程序提示不能加载PostgreSQL客户端动态库“libpq.dll“
  12. python 随机生成电话号码、密码、用户名
  13. Bumped!详解—(Dijkstra堆优化,优先队列实现,结构体重载运算符)
  14. scroll-view
  15. 学习arduino esp32相关例程(1)深度睡眠与唤醒
  16. 如何设置Windows扩展屏幕,扩展屏幕和主屏有何区别,如何优化使用扩展屏幕?
  17. Oracle数据库怎么调大字体,CFree怎么调大字体 设置字体大小的方法
  18. delphic oracle下载,Chemical Oracle
  19. VMware打开虚拟机,会立即导致宿主机重启
  20. 计算机c盘加容量,两种方法,给电脑C盘增加10G的容量,电脑焕然一新

热门文章

  1. 苹果手机人脸识别不了是什么原因_安卓手机越用越卡顿,为何苹果手机不会?离不开这3点原因...
  2. arp命令linux上,arp命令 - Linux命令大全 | linux教程
  3. 少儿python用幼儿书籍_小朋友的书 篇一:一岁半小朋友图书大总结(中文系列)...
  4. 学好C语言需要的五本书
  5. unplugin-auto-import的使用
  6. Linux之标准错误码(全)(三十七)
  7. python写测试用例怎么样_Python自动化测试怎么样,我想学习?
  8. 天天ASP开发网完成拼车网项目开发
  9. 【Echarts】 从入门到自定义封装组件
  10. 2018计算机全国考研学校排名,2018计算机专业学校考研难度排行榜,计算机考研难度排名...