文档章节

dd测试硬盘性能

 小小人故事
发布于 2015/12/25 10:29
字数 1088
阅读 17
收藏 2

下面直接介绍几种常见的DD命令,先看一下他的区别~

dd if=/dev/zero of=test bs=64K count=1
dd if=/dev/zero of=test bs=64K  count=1; sync
dd if=/dev/zero of=test bs=64K  count=1 conv=fdatasync
dd if=/dev/zero of=test bs=64K  count=1 oflag=dsync


这四条DD命令区别在于内存中写缓存的处理方式。

1.

dd if=/dev/zero of=test bs=64K  count=1

  没有加任何参数,dd默认的方式不包括“同步(sync)”命令。也就是说,dd命令完成前并没有让系统真正把文件写到磁盘上。所以以上命令只是单纯地把这128MB的数据读到内存缓冲当中(写缓存[write cache])。所以你得到的将是一个超级快的速度。因为其实dd给你的只是读取速度,直到dd完成后系统才开始真正往磁盘上写数据,但这个速度你是看不到了。所以如果这个速度很快,没有什么作用。

实际运行结果:

记录了1+0 的读入
记录了1+0 的写出
104857600字节(105 MB)已复制,2.00737 秒,52.2 MB/秒

2.

dd if=/dev/zero of=test bs=64K  count=1; sync

  和前面1中的完全一样。分号隔开的只是先后两个独立的命令。当sync命令准备开始往磁盘上真正写入数据的时候,前面dd命令已经把错误的“写入速度”值显示在屏幕上了。所以你还是得不到真正的写入速度。

实际运行结果:

记录了1+0 的读入
记录了1+0 的写出
104857600字节(105 MB)已复制,2.06546 秒,50.8 MB/秒

3.

dd if=/dev/zero of=test bs=64K count=1 conv=fdatasync

  加入这个参数后,dd命令执行到最后会真正执行一次“同步(sync)”操作,所以这时候你得到的是读取这128M数据到内存并写入到磁盘上所需的时间,这样算出来的时间才是比较符合实际使用结果的。

实际运行结果:

记录了1+0 的读入
记录了1+0 的写出
104857600字节(105 MB)已复制,2.59843 秒,40.4 MB/秒

4.

dd if=/dev/zero of=test bs=64K count=1 oflag=dsync

  加入这个参数后,dd在执行时每次都会进行同步写入操作。也就是说,这条命令每次读取64k后就要先把这64k写入磁盘,然后再读取下面这64k,一共重复128次。这可能是最慢的一种方式了,因为基本上没有用到写缓存(write cache)。

实际运行结果:

记录了1+0 的读入
记录了1+0 的写出
104857600字节(105 MB)已复制,2.0844 秒,50.3 MB/秒

  一般来说,第四种方法是最严格的,可以模拟数据库的插入操作,所以很慢,也是用来测试vps硬盘性能标准的一条标杆,一般来说测试结果,如果超过10M,对正常建站就无影响。超过50M,就是非常给力状态,看了这个vps硬盘性能非常的好,DD速度达到了78.9MB/s。

  在这几条命令中,bs=64k表示同时读入/输出的块大小为64k个字节,count=4k表示拷贝块的个数为4000个,如果测试再严格一点,我们运行1G数据量的DD:

dd if=/dev/zero of=test1 bs=64k count=16k oflag=dsync
表示每个块大小为64k个字节,测试16k个数量的块,实际测试结果:

记录了16384+0 的读入
记录了16384+0 的写出
1073741824字节(1.1 GB)已复制,125.424 秒,8.6 MB/秒

#阿里云硬盘真够烂的

#看另一台国外的vps
[root@166087 ~]# dd if=/dev/zero of=test1 bs=64k count=16k oflag=dsync
记录了16384+0 的读入
记录了16384+0 的写出
1073741824字节(1.1 GB)已复制,15.0148 秒,71.5 MB/秒

  写到这里,我觉得利用DD命令测试硬盘应该很清楚了,通常我们测试用第四条命令即可,当然DD越快并不能代表服务器的性能好坏,普通硬盘的服务器执行DD命令结果在30M左右就不错了,另外,执行DD命令测试硬盘IO性能,对硬盘的损害很大,不建议多次或长时间尝试!


© 著作权归作者所有

粉丝 3
博文 73
码字总数 22668
作品 0
昌平
私信 提问

暂无文章

Giraph源码分析(八)—— 统计每个SuperStep中参与计算的顶点数目

作者|白松 目的:科研中,需要分析在每次迭代过程中参与计算的顶点数目,来进一步优化系统。比如,在SSSP的compute()方法最后一行,都会把当前顶点voteToHalt,即变为InActive状态。所以每次...

数澜科技
今天
4
0
Xss过滤器(Java)

问题 最近旧的系统,遇到Xss安全问题。这个系统采用用的是spring mvc的maven工程。 解决 maven依赖配置 <properties><easapi.version>2.2.0.0</easapi.version></properties><dependenci......

亚林瓜子
今天
10
0
Navicat 快捷键

操作 结果 ctrl+q 打开查询窗口 ctrl+/ 注释sql语句 ctrl+shift +/ 解除注释 ctrl+r 运行查询窗口的sql语句 ctrl+shift+r 只运行选中的sql语句 F6 打开一个mysql命令行窗口 ctrl+l 删除一行 ...

低至一折起
今天
9
0
Set 和 Map

Set 1:基本概念 类数组对象, 内部元素唯一 let set = new Set([1, 2, 3, 2, 1]); console.log(set); // Set(3){ 1, 2, 3 } [...set]; // [1, 2, 3] 接收数组或迭代器对象 ...

凌兮洛
今天
4
0
PyTorch入门笔记一

张量 引入pytorch,生成一个随机的5x3张量 >>> from __future__ import print_function>>> import torch>>> x = torch.rand(5, 3)>>> print(x)tensor([[0.5555, 0.7301, 0.5655],......

仪山湖
今天
6
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部