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

1

2

3

4

5

6

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

Linux:
%iowait
Percentage of time that the CPU or CPUs were idle during
which the system had an outstanding disk I/O request.

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不能工作的时间,二是误以为 %iowait 表示I/O有瓶颈。

第一种误解太低级了,%iowait 的首要条件就是CPU空闲,既然空闲当然就可以接受运行任务,只是因为没有可运行的进程,CPU才进入空闲状态的。那为什么没有可运行的进程呢?因为进程都处于休眠状态、在等待某个特定事件:比如等待定时器、或者来自网络的数据、或者键盘输入、或者等待I/O操作完成,等等。

第二种误解更常见,为什么人们会认为 %iowait 偏高是有I/O瓶颈的迹象呢?他们的理由是:”%iowait  的第一个条件是CPU空闲,意即所有的进程都在休眠,第二个条件是仍有未完成的I/O请求,意味着进程休眠的原因是等待I/O,而 %iowait 升高则表明因等待I/O而休眠的进程数量更多了、或者进程因等待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等指标有没有明显增大,应用有没有感觉变慢,如果都没有,就没什么好担心的。

理解 %IOWAIT (%WIO)相关推荐

  1. 如何理解 iowait

    Linux中,%iowait 过高可能是个问题,严重的时候,它能使服务停止, 但问题是,多高才算高? 什么时候应该担心呢? 本文将讨论 iowait 的含义.相关的统计数据.原理以及 iowait的瓶 ...

  2. rxswift 网络请求_使用RxSwift将身份验证请求链接到多个服务

    rxswift 网络请求 At a company that I have worked in the past, a high-traffic online classifieds, the bac ...

  3. linux sed 测试文件夹,测试开发笔记二(Linux与Shell脚本)

    01 | Linux系统和Shell环境准备 运行shell test.sh #!/bin/bash echo "hello" 运行脚本 方式一: chmod+x ./test.s ...

  4. TOP 命令中wio的正确理解

    %iowait 是 "sar -u" 等工具检查CPU使用率时显示的一个指标,在Linux上显示为 %iowait,在有的Unix版本上显示为 %wio,含义都是一样的,这个指标常 ...

  5. 磁盘负载指标 %iowait, await, %util 的正确理解

    说明 %iowait, await, %util 是用来衡量硬盘负载的三个指标, 但是这几个指标通常容易被误解, 实际上, 这三个指标单纯的高, 并不一定能说明相应的磁盘有问题或者有瓶颈, 而是需要结 ...

  6. hd disk / disk raid / disk io / iops / iostat / iowait / iotop / iometer

    DISK IOPS / Input/Output Operations Per Second http://baike.baidu.com/view/2302083.htm IOPS (Input/O ...

  7. linux cpu平均利用率st,理解 CPU 利用率

    从 top 命令说起 在 Linux shell 上执行 top 命令,可以看到这样一行 CPU 利用率的数据: %Cpu(s): 0.1 us, 0.0 sy, 0.0 ni, 99.9 id, 0 ...

  8. 理解Linux的性能

    项目中常遇到需要对目前运行的系统进行效率分析,或碰到客户咨询如何优化系统的效率问题.更多的情况是,在系统出现问题的时候,需要分析原因,定位系统故障或瓶颈,当然,最好是可以一并解决故障.但实际上,操作系 ...

  9. 怎么理解linux的平均负载及平均负载高后的排查工具

    什么是平均负载 平均负载可以对于我们来说及熟悉又陌生,但我们问平均负载是什么,但大部分人都回答说平均负载不就是单位时间内CPU使用率吗?其实并不是这样的,如果可以的话,可以 man uptime 来了 ...

最新文章

  1. 深度解析 | 大数据面前,统计学的价值在哪里?
  2. 【SpringCloud】Feigin-实例
  3. val, lazy, def
  4. linux驱动(七)gpiolib库详解
  5. 前端学习(3005):vue+element今日头条管理--处理布局完成
  6. Python深度学习:Python数据处理及可视化(读书笔记)
  7. [曲线拟合]使用Tensorflow拟合COS函数
  8. 抖音文案、声音、设计、视频、图片素材网站
  9. Android Studio中Intent的一些相关知识
  10. 色彩管理实验 matlab,EFI色彩管理实验指导手册.doc
  11. php cms下载地址,phpcms将下载地址替换为图片显示
  12. 【MobileNet V2】《MobileNetV2:Inverted Residuals and Linear Bottlenecks》
  13. iPhone 录音如何去除背景杂音增强录音品质
  14. 在win10系统上使用Hyper-v创建虚拟机(win7)并设置文件共享
  15. Android性能优化系列篇(三):崩溃优化+卡顿优化
  16. HOW TO:Be more productive aaron swartz
  17. Java实时处理 - Spring Integration - MQ Message
  18. sed在匹配行前面或者后面插入一行
  19. 搭建一个简易的本地Python源服务器
  20. 小白读《锋利的jQuery(第2版)》第五章学习笔记(表单、表格)

热门文章

  1. java的depot类有什么方法_HP-UNIX depot软件安装方法
  2. eclipse常见问题
  3. 弹性响应蒸馏 | 用弹性响应蒸馏克服增量目标检测中的灾难性遗忘
  4. 【Verilog基础】CMOS逻辑门实现基础功能(反相器/与非门/或非门/与门/或门)
  5. FPGA练习:与门电路的实现
  6. 智力题---100个球两个人轮流拿,每次最多拿n个,谁拿到最后一个球获胜
  7. 【python种子项目ppc】保姆级别指导给项目添加测试
  8. puppy linux u盘,Puppy Linux v4.0 下载 可安装在U盘上的操作系统
  9. vue.js中实现方法内某些代码延时执行
  10. Android 中英文切换及遇到的问题