%iowait 是 “sar -u” 等工具检查CPU使用率时显示的一个指标,在Linux上显示为 %iowait,在有的Unix版本上显示为 %wio,含义都是一样的,这个指标常常被误读,很多人把它当作I/O问题的征兆,我自己每隔一段时间就会遇到对 %iowait 紧张兮兮的客户,不得不费尽唇舌反复解释,事实上这个指标所含的信息量非常少,不能单独用来判断系统有没有I/O问题,在此我们详细探讨一下它真正的含义,先从man page上的解释开始:

09:35:06 AM CPU %user %nice %system %iowait %steal %idle 09:35:07 AM all 0.00 0.00 0.00 0.00 0.00 100.00 09:35:08 AM all 0.51 0.00 2.53 13.13 0.00 83.84 09:35:09 AM all 1.54 0.00 7.69 39.49 0.00 51.28 09:35:10 AM all 2.04 0.00 9.18 39.80 0.00 48.98 09:35:11 AM all 1.02 0.00 7.65 40.31 0.00 51.02

下面是man page中的部分解释:

  • Linux:
%iowait Percentage of time that the CPU or CPUs were idle during which the system had an outstanding disk I/O request.
  1. HP-UX:
%wio idle with some process waiting for I/O (only block I/O, raw I/O, or VM pageins/swapins indicated).

Linux和HP-UX的man page分别从两个角度描述了这个指标:Linux着眼于I/O,强调的是仍有未完成的I/O请求;而HP-UX着眼于进程,强调的是仍有进程在等待I/O,二者所说的是同一件事的两个方面,如果合在一起就完整了,就是:至少有一个I/O请求尚未完成,有进程因为等待它而休眠,我们不妨采纳Linux的措辞,%iowait 表示在一个采样周期内有百分之几的时间属于以下情况:CPU空闲、并且有仍未完成的I/O请求。
对 %iowait 常见的误解有两个:

  • 是误以为 %iowait 表示CPU不能工作的时间
  1. 这种误解太低级了,%iowait 的首要条件就是CPU空闲,既然空闲当然就可以接受运行任务,只是因为没有进程可以运行,CPU才进入空闲状态的。那为什么没有进程可以运行呢?因为进程都处于休眠状态、在等待某个特定事件:比如等待定时器、或者来自网络的数据、或者键盘输入、或者等待I/O操作完成,等等。
  • 是误以为 %iowait 表示I/O有瓶颈问题
  1. 为什么人们会认为 %iowait 偏高是有I/O问题的迹象呢?他们的理由是:”%iowait 的第一个条件是CPU空闲,意即所有的进程都在休眠,第二个条件是仍有未完成的I/O请求,意味着进程休眠的原因是等待I/O,而 %iowait 升高则表明因等待I/O而休眠的进程数量更多了、或者进程因等待I/O而休眠的时间更长了。“ 听上去似乎很有道理,但是不对:首先 %iowait 确实表示CPU空闲、所有进程都在休眠,也确实有的进程在等待I/O,然而 %iowait 升高并不能证明等待I/O的进程数量增多了,也不能证明等待I/O的总时间增加了。

为什么呢?看看下面两张图就明白了:

第一张图演示的是:在I/O完全一样的情况下,CPU忙闲状态的变化就能够影响 %iowait 的大小,图中我们看到,在CPU繁忙期间发生的I/O,无论有多少,%iowait 的值都是不受影响的(因为 %iowait 的第一个前提条件就是CPU必须空闲);当CPU繁忙程度下降时,有一部分I/O落入了CPU空闲的时间段内,这就导致了 %iowait 升高,可见,I/O并没有变化,%iowait 却升高了,原因仅仅是CPU的空闲时间增加了,请记住,系统中有成百上千的进程数,任何一个进程都可以引起CPU和I/O的变化,因为 %iowait、%idle、%user、%system 等这些指标都是全局性的,并不是特指某个进程。

再看第二张图,它描述了另一种情形:假设CPU的繁忙状况保持不变的条件下,即使 %iowait 升高也不能说明I/O负载加重了,如果2个I/O请求依次提交、使得整个时段内始终有I/O在进行,那么 %iowait 是100%;如果3个I/O请求同时提交,因为系统有能力同时处理多个I/O,所以3个并发的I/O从开始到结束的时间与一个I/O一样,%iowait 的结果只有50%;2个I/O使 %iowait 达到了100%,3个I/O的 %iowait 却只有50%,显然 %iowait 的高低与I/O的多少没有必然关系,而是与I/O的并发度相关,所以,仅凭 %iowait 的上升不能得出I/O负载增加 的结论。

这就是为什么说 %iowait 所含的信息量非常少的原因,它是一个非常模糊的指标,如果看到 %iowait 升高,还需检查I/O量有没有明显增加,avserv/avwait/avque等指标有没有明显增大,应用有没有感觉变慢,如果都没有,就没什么好担心的。

TOP 命令中wio的正确理解相关推荐

  1. c语言中aver是什么意思_Linux系统top命令中的io使用率,到底是什么意思?

    最近在做连续数据流的缓冲系统,C语言代码实现后,粗略测试了下,功能上应该没有问题.那么,接下来就该测试性能了.输入 top 命令,的确可以看到一系列 cpu 使用率,其中一个值得注意的子项就是 io ...

  2. 聊聊 top 命令中的 CPU 使用率

    之前写过cpu占用率的文章 CPU占用率是什么? ==== 平常我们使用 top 命令来查看系统的性能情况,在 top 命令中可以看到很多不同类型的 CPU 使用率,如下图红框中标出部分: 下面,我们 ...

  3. linux中top命令cpu,ps命令中的%CPU字段和top命令中的%CPU字段

    一.ps命令中%CPU字段的含义 1."man ps"中的解释 CPU usage is currently expressed as the percentage of time ...

  4. linux top 显示swap,Linux top命令中的SWAP与DATA

    记得前面的一篇日志中提到过,Linux top命令中的SWAP是通过 VIRT – RSS计算出来的:但是SWAP真的就代表占用磁盘的SWAP的空间大小吗? 我们知道linux的内存使用是采用记账的方 ...

  5. linux环境中,top命令中,对command的命令进行扩展查看详情?

    需求说明: 在使用top命令进行资源情况使用查看时,经常出现以下情况: 备注:也就是说,在COMMAND列中,有多个java进程,想要知道每个java具体的对应的是哪个程序的进程. 通过top命令的c ...

  6. linux6.5 查看分辨率命令,centos6.5跟centos7的top命令中移动查看顺序的指令怎么不一样...

    top 命令 移动查看顺序 centos6.5 以下 top -ab -n 1 按o 按大写字母可以调顺序 大写字母往左 小写往右 f,o . Fields/Columns: 'f' add or r ...

  7. Top 命令中的 Irix 模式与 Solaris 模式(解释单个进程cpu占比为何会超过100%?)

    文章目录 背景 top cpu 栏位说明 Solaris 模式 Irix Mode TOP -H切换线程 总结 背景 关于top命令用了很久了,但是一直对单进程占用cpu占比为何会超过100%认识不够 ...

  8. 一文辨析,性能分析top命令中进程NI和PR

    ✒️分析 Linux 服务器性能,首先想到的命令肯定是 top, 通过它,我们可以看到当前服务器资源使用情况和进程运行资源占用情况. 在查看进程资源占用情况时,有两列大家是最难区分,PR(priori ...

  9. Linux 在 TOP 命令中切换内存的显示单位

    2019独角兽企业重金招聘Python工程师标准>>> 顶部的内存信息可以在top运行时按E切换,每次切换转换率为1000,只是没有单位,切换的单位为 k,m,g,t,p: 底下的进 ...

最新文章

  1. python网络安全怎么学_学习网络安全包住宿
  2. mongodb带认证的副本集搭建
  3. php 命令行方式运行时 几种传入参数的方式
  4. [教程]一份简单易懂的 TensorFlow 教程
  5. 在html中 正确的嵌套方式是( ).,HTML及网页制作练习题-完整版
  6. flutter ios上踩的一个坑
  7. html文档head,HTML的head标签
  8. android 每日构建_Android构建类型和产品风味
  9. 关于CWMP基础(一)----(TR069)
  10. 《生产实习》实习日志——JAVA大数据工程师
  11. fspecial matlab 自己实现,matlab中fspecial中生成高斯模板的解释以及c语言兑现
  12. 使用codeigniter_使用CodeIgniter解开MVC
  13. 一些符号及颜色的英语写法总结
  14. 量化交易学习笔记(13) 交易数据获取(优化版本)
  15. 安装系统遇到MBR的硬盘,EFI系统只能安装GPT硬盘
  16. 先序序列和后序序列并不能唯一确定二叉树
  17. SQL Server Intergration Services(SSIS)
  18. 《神经科学:探索脑》学习笔记(第19章 脑的节律)
  19. QT 实现图片旋转及缩放
  20. google账号登录第三方平台实现

热门文章

  1. fastjson 序列化 不包括转义字符_CVE-2020-14644 weblogic iiop反序列化漏洞分析
  2. C/C++语言拾遗(三)-多字节字符和Unicode
  3. 基于Spring boot+freemarker+Mysql实现的玩具企业官网项目源码
  4. 评价计算机系统性能的综合指标,信息系统性能评价包含哪些指标
  5. 数据库基础知识(必读)
  6. ADB常用命令和Monkey命令
  7. java错误无法读取配置文件_解决Java Web项目无法读取配置文件问题
  8. Python微信打飞机游戏编程学习笔记01
  9. 如何修改EDI系统schema版本
  10. Heritrix Eclipse下环境配置