请问/proc/diskstats 文件中 IO操作花费的加权毫秒数 是什么意思?

发布于 2022-09-12 23:25:11 字数 223 浏览 29 评论 0

我读/proc/diskstats这个文件中每行第12个字段是加权毫秒数。

我不太理解这个字段是什么意思,有没有大佬讲解下,拜托了!

是指IO积压的队列长度吗?

参考:https://www.kernel.org/doc/Do...

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

像极了他 2022-09-19 23:25:11

weighted # of milliseconds spent doing I/Os 的计算: IO 开始、合并、完成,还有读这些统计信息时,递增 (当前并发执行的 IO 数 * 距离上次更新的时间).

举个例子,连续发起了 3 个 IO 操作,每个间隔 2ms,每个都耗时 4ms:

时间      0     1     2     3     4     5     6     7     8     9
         |-----|-----|-----|-----|-----|-----|-----|-----|-----|
IO  1     XXXXXXXXXXXXXXXXXXXXXXXX
IO  2                 XXXXXXXXXXXXXXXXXXXXXXXX
IO  3                             XXXXXXXXXXXXXXXXXXXXXXXX

开始时 sum = 0;

第 0 秒时,IO 1 开始,sum += 当前并发执行 IO 数 0 * 距离上次更新时间 0, sum = 0;

第 2 秒时,IO 2 开始,sum += 当前并发执行 IO 数 1 * 距离上次更新时间 2, sum = 0 + 2

第 4 秒时,IO 1 结束,sum += 当前并发执行 IO 数 2 * 距离上次更新时间 2, sum = 2 + 4 = 6;

第 4 秒时,IO 3 开始,sum += 当前并发执行 IO 数 1 * 距离上次更新时间 0, sum = 6 + 0 = 6

第 6 秒时,IO 2 结束,sum += 当前并发执行 IO 数 2 * 距离上次更新时间 2, sum = 6 + 4 = 10

第 8 秒时,IO 3 结束,sum += 当前并发执行 IO 数 1 * 距离上次更新时间 2, sum = 10 + 2 = 12

(这里IO 开始时,不把当前 IO 算在并发执行 IO; IO 结束时,把当前 IO 算在当前并发 IO,不确定内核是不是这样的)

这个方式算的其实就是 X 的面积(or 长度),就是 IO 执行时间(3 * 4 = 12 ms)。而没加权的毫秒数是 8 ms。

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文