下面的测试方法受到缓存的影响,2.5寸,5400转的ATAT笔记本硬盘,不可能速度达到368MB/s,所以肯定先写缓存了
steve@steve-Inspiron-6000:~/temp$ time dd if=/dev/zero of=./test1 bs=64k count=1000
1000+0 records in
1000+0 records out
65536000 bytes (66 MB) copied, 0.177868 s, 368 MB/s
用/dev/urandom可写入随机数据
time dd if=/dev/urandom of=./test1 bs=64k count=1000
Linux 中直接 I/O 机制的介绍(此文有对linux direct I/O的精彩介绍)
http://www.ibm.com/developerworks/cn/linux/l-cn-directio/
使用oflag=direct表示使用DirectIO方式,速度降到33.6MB/S,比较符合实际情况
steve@steve-Inspiron-6000:~/temp$ time dd if=/dev/zero of=./test2 bs=64k count=1000 oflag=direct
1000+0 records in
1000+0 records out
65536000 bytes (66 MB) copied, 1.94967 s, 33.6 MB/s
real 0m1.953s
user 0m0.000s
sys 0m0.144s
在dd命令结束前同步数据和元数据(metaData)
steve@steve-Inspiron-6000:~/temp$ time dd if=/dev/zero of=./test3 bs=64k count=1000 conv=fsync
1000+0 records in
1000+0 records out
65536000 bytes (66 MB) copied, 2.83524 s, 23.1 MB/s
real 0m2.839s
user 0m0.000s
sys 0m0.168s
在dd命令结束前只同步数据
steve@steve-Inspiron-6000:~/temp$ time dd if=/dev/zero of=./test1 bs=64k count=1000 conv=fdatasync
1000+0 records in
1000+0 records out
65536000 bytes (66 MB) copied, 2.78156 s, 23.6 MB/s
real 0m2.785s
user 0m0.004s
sys 0m0.168s
使用同步I/O,每次写都要物理写入磁盘(磁盘会狂响的^_^),巨慢
steve@steve-Inspiron-6000:~/temp$ time dd if=/dev/zero of=./test2 bs=64k count=1000 oflag=sync
1000+0 records in
1000+0 records out
65536000 bytes (66 MB) copied, 48.4128 s, 1.4 MB/s
real 0m48.416s
user 0m0.000s
sys 0m0.364s
oflag=dsync只同步写数据
steve@steve-Inspiron-6000:~/temp$ time dd if=/dev/zero of=./test2 bs=64k count=1000 oflag=dsync
1000+0 records in
1000+0 records out
65536000 bytes (66 MB) copied, 48.4673 s, 1.4 MB/s
real 0m48.491s
user 0m0.004s
sys 0m0.380s
非阻塞I/O, 可以调用不会永远阻塞的 I/O 操作,例如 open, read 和 write 。如果这种操作不能完成,则立即出错返回,应用程序需要主动重试
steve@steve-Inspiron-6000:~/temp$ time dd if=/dev/zero of=./test5 bs=64k count=1000 oflag=nonblock
1000+0 records in
1000+0 records out
65536000 bytes (66 MB) copied, 0.144059 s, 455 MB/s
real 0m0.148s
user 0m0.000s
sys 0m0.128s
本文出自 “让我men共同成长” 博客,谢绝转载!