iflag=nocache
的标志dd
似乎只在第二次以后才生效。
我不明白为什么。
我在想也许它与预读缓存有关,但它没有解释下表中的结果:
Results - Effect of iflag=nocache: from big SATA SSD file to /dev/null:
Test_Name dd_flags Time[s] time/dd exit status
w/ iflag=nocache iflag=nocache 6.95 0
again w/ iflag=nocache iflag=nocache 6.94 0
first w/o iflag=nocache - 6.94 0
2nd w/o iflag=nocache - 2.60 0
3nd w/o iflag=nocache - 2.49 0
first w/ iflag=nocache iflag=nocache 2.71 0
2nd w/ iflag=nocache iflag=nocache 6.94 0
3rd w/ iflag=nocache iflag=nocache 6.94 0
关于底部的 3 个测试/行:
- 第一次
iflag=nocache
使用,然后仍然使用缓存(由于它花费的时间很快)。 - 最后两次尝试
iflag=nocache
花费了很长时间(即没有缓存),这意味着他们可能没有使用预读缓存,所以预读缓存可能不是这里的问题。 - 该
iflag=nocache
标志似乎有效,因为随后使用它的尝试要慢得多,这意味着没有使用缓存。
笔记:
- 上表中的列
dd_flags
显示了提供给 的所有标志dd
,除了两个标志if
和of
。对于具有列的行-
,dd_flags
这意味着dd
没有额外的标志(除了if
andof
) - 输入文件
dd
是一个大文件(3.8GB),存储在 SATA SSD 中(最大吞吐量约 500MB)。 - 的输出文件
dd
是 /dev/null。 - 上表中的
Time[s]
列是实时,它是time
Bash 保留字的结果。 - 我不执行同步,因为不需要 - 文件是在 PC 启动之前写入的。
- 我不清空操作系统页面缓存(使用
echo 1 >|/proc/sys/vm/drop_caches
),因为我想避免完全缓存失效。
我尝试删除整个文件的缓存,如所示info dd
- 似乎有效:
Results - Effect of iflag=nocache: from big SATA SSD file to /dev/null:
Test_Name dd_flags Time[s] time/dd exit status
w/ iflag=nocache iflag=nocache 6.95 0
again w/ iflag=nocache iflag=nocache 6.95 0
first w/o iflag=nocache - 6.94 0
2nd w/o iflag=nocache - 2.60 0
3nd w/o iflag=nocache - 2.49 0
Drop cache for whole file iflag=nocache,count=0 0.14 0
first w/ iflag=nocache iflag=nocache 6.94 0
2nd w/ iflag=nocache iflag=nocache 6.94 0
3rd w/ iflag=nocache iflag=nocache 6.94 0
版本:
$ dd --version | head -1
dd (coreutils) 8.32
没有解决我的问题的相关阅读:
https://www.gnu.org/software/coreutils/manual/html_node/dd-invocation.html#dd-invocation
那是因为
iflag=nocache
删除缓存......在它被读取之后,而不是之前。如果您使用 strace,您可以看到这一点:
每次读取都带有一个
POSIX_FADV_DONTNEED
范围,该范围涵盖了先前已读取的内容。它与读取不完全匹配,因为 POSIX_FADV_DONTNEED 需要与 dd 使用的块大小不同的对齐方式。但最终它仍然会丢弃先前读取的块的缓存。
因此,如果您的意图是读取未缓存的数据,此 iflag 将无济于事。(*)
相反,目的是不缓存已读取的内容,也不替换之前已缓存的其他内容。这是一种在不过多干扰现有缓存的情况下复制或流式传输大文件的方法。
man 2 posix_fadvise
这样描述它:所以它是针对已经使用(已经被dd读取)但不保存在缓存中的数据,以免丢弃更多有用的东西。
(*)
info dd
将此示例列为一种无需读取即可删除整个文件的缓存的方法:nocache 标志的描述也比联机帮助页更详细,因此可能值得一读。