`
yhz61010
  • 浏览: 551915 次
  • 来自: -
博客专栏
63c13ecc-ef01-31cf-984e-de461c7dfde8
libgdx 游戏开发
浏览量:11990
社区版块
存档分类
最新评论

[原创] dd 命令进行磁盘测试及 conv 和 oflag 参数的说明

阅读更多
使用 dd 命令进行磁盘读写测试,相认大家可能都做过,尤其是在测试 VPS 磁盘性能时。

关于该命令的及其参数的详细说明,请查看手册(执行如下命令):
info coreutils 'dd invocation'
如果你在进行磁盘性能测试时,使用的是下面的命令:
dd if=/dev/zero of=test bs=64k count=4k
那么,请你继续看本文。因为这么测试得到的结果是不准确的。

现在我们再来回顾下如下两个常用命令:

模拟数据库插入操作(少量数据频繁写入测试)
dd if=/dev/zero of=test bs=64k count=4k oflag=dsync
大数据连续写入测试
dd if=/dev/zero of=test bs=8k count=256k conv=fdatasync
先介绍下 conv 参数 CONVS 的含义:
‘fdatasync’
  Synchronize output data just before finishing.  This forces a
  physical write of output data.

‘fsync’
  Synchronize output data and metadata just before finishing.
  This forces a physical write of output data and metadata.

这两个参数的区别就在于是否写入元数据。

再介绍下 oflag 参数 FLAGS 的含义:
‘dsync’
  Use synchronized I/O for data.  For the output file, this
  forces a physical write of output data on each write.  For the
  input file, this flag can matter when reading from a remote
  file that has been written to synchronously by some other
  process.  Metadata (e.g., last-access and last-modified time)
  is not necessarily synchronized.

‘sync’
  Use synchronized I/O for both data and metadata.

这两个参数的区别也在于是否写入元数据。

看完了参数说明,我们再来说说上面的两行命令,这两行命令,都是测试磁盘写入性能的,只不过执行第一个命令时,需要很长的时间(以下测试数据来源于我在 AWS 上的免费 EC2 服务器。OS: RHEL7.3 64位):
$ dd if=/dev/zero of=test bs=64k count=4k oflag=dsync
记录了4096+0 的读入
记录了4096+0 的写出
268435456字节(268 MB)已复制,48.6814 秒,5.5 MB/秒
$ dd if=/dev/zero of=test bs=8k count=256k conv=fdatasync
记录了262144+0 的读入
记录了262144+0 的写出
2147483648字节(2.1 GB)已复制,41.277 秒,52.0 MB/秒
我们会发现第一行命令执行完,仅生成了 268 MB 的数据,用时却长达 48+ 秒。
而第二行命令执行完,虽然生成了 2.1GB 的数据,比第一行命令生成的数据大的多,但是用时却只有 41+ 秒,反而用时少。
为什么呢?

请注意下 oflag=dsync 参数,这个参数表明每当需要写数据时都会真正到写到磁盘上,等写到磁盘上之后,才会继续开始下一次数据写入。第一行命令要求反复写 4k 次数据,也就是说,会真正写磁盘 4k 次,用时长是理所当然的。

而第二行命令,虽然总共要写 2.1 GB 的数据,但是由于使用的是 conv=fdatasync 参数,也就是说,当 dd 命令结束前,一次性把所有的数据写到磁盘上,因此写入速度非常快。

我们再做一个测试,还是使用上面两个命令,参数相同,不同的仅是 count 参数设置为 1,bs 设置为 256 MB。那么根据之前的说明,我们可以推测,两次测试的结果应该是相近的。
$ dd if=/dev/zero of=test bs=256MB count=1 oflag=dsync
记录了1+0 的读入
记录了1+0 的写出
256000000字节(256 MB)已复制,3.85186 秒,66.5 MB/秒
$ dd if=/dev/zero of=test bs=256MB count=1 conv=fdatasync
记录了1+0 的读入
记录了1+0 的写出
256000000字节(256 MB)已复制,4.23802 秒,60.4 MB/秒

引用地址:
http://www.hostloc.com/thread-256990-1-1.html
http://blog.csdn.net/menogen/article/details/38059671
0
0
分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics