由于 dd 命令执行完毕之后,会打印 dd 过程中数据拷贝的速度,因此有许多人用 dd 来对磁盘的 I/O 进行测试,希望以其结果作为参考数据,对比不同服务商或不同硬件配置下,磁盘的读写能力。尽管在命令执行完毕之后,会显示一个平均速度,但在执行过程中,是不显示任何信息的,这就导致在拷贝大体积文件的时候,操作人员陷入无尽的等待。
本文将介绍观测正在运行的 dd 的进度,希望这个方法对大家有帮助。
第一步:新建一个窗口,查找当前 dd 命令对应的 PID
其结果:
8269 dd.8269 dd
第二步:向 dd 进程发送 USR1 指令
此时,你将在正在执行 dd 命令的窗口中,看到已经拷贝了的数据大小,以及每秒的速度。
当然,如果你只有一个 dd 进程在执行,也可以直接用下面这个命令:
如果十分迫不及待,可以用这个命令,每隔一秒输出一次:
当然,你也可以这样,在执行 dd 命令的时候,就让他自动不断输出:
dd 参数解释
1. if=文件名:输入文件名,缺省为标准输入。即指定源文件。< if=input file >
2. of=文件名:输出文件名,缺省为标准输出。即指定目的文件。< of=output file >
3. ibs=bytes:一次读入bytes个字节,即指定一个块大小为bytes个字节。
obs=bytes:一次输出bytes个字节,即指定一个块大小为bytes个字节。
bs=bytes:同时设置读入/输出的块大小为bytes个字节。
4. cbs=bytes:一次转换bytes个字节,即指定转换缓冲区大小。
5. skip=blocks:从输入文件开头跳过blocks个块后再开始复制。
6. seek=blocks:从输出文件开头跳过blocks个块后再开始复制。
注意:通常只用当输出文件是磁盘或磁带时才有效,即备份到磁盘或磁带时才有效。
7. count=blocks:仅拷贝blocks个块,块大小等于ibs指定的字节数。
8. conv=conversion:用指定的参数转换文件。
ascii:转换ebcdic为ascii
ebcdic:转换ascii为ebcdic
ibm:转换ascii为alternate ebcdic
block:把每一行转换为长度为cbs,不足部分用空格填充
unblock:使每一行的长度都为cbs,不足部分用空格填充
lcase:把大写字符转换为小写字符
ucase:把小写字符转换为大写字符
swab:交换输入的每对字节
noerror:出错时不停止
notrunc:不截短输出文件
sync:将每个输入块填充到ibs个字节,不足部分用空(NUL)字符补齐。
dd 的一些应用实例
1.将本地的/dev/hdb整盘备份到/dev/hdd
2.将/dev/hdb全盘数据备份到指定路径的image文件
3.将备份文件恢复到指定盘
4.备份/dev/hdb全盘数据,并利用gzip工具进行压缩,保存到指定路径
5.将压缩的备份文件恢复到指定盘
6.备份磁盘开始的512个字节大小的MBR信息到指定文件
7.备份软盘
8.拷贝内存内容到硬盘
9.拷贝光盘内容到指定文件夹,并保存为cd.iso文件
10.增加swap分区文件大小
11.销毁磁盘数据
12.测试硬盘的读写速度
13.确定硬盘的最佳块大小:
14.修复硬盘
当硬盘较长时间(比如1,2年)放置不使用后,磁盘上会产生magnetic fluxpoint。当磁头读到这些区域时会遇到困难,并可能导致I/O错误。当这种情况影响到硬盘的第一个扇区时,可能导致硬盘报废。上边的命令有可能使这些数据起死回生。且这个过程是安全,高效的。