dd使用教程

dd是 Linux/UNIX 下的一个非常有用的命令,作用是用指定大小的块拷贝一个文件,并在拷贝的同时进行指定的转换。

dd的语法

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
if =输入文件(或设备名称)。
of =输出文件(或设备名称)。
ibs = bytes 一次读取bytes字节,即读入缓冲区的字节数。
skip = blocks 跳过读入缓冲区开头的ibs*blocks块。
obs = bytes 一次写入bytes字节,即写入缓冲区的字节数。
bs = bytes 同时设置读/写缓冲区的字节数(等于设置ibs和obs)。
cbs = byte 一次转换bytes字节。
count=blocks 只拷贝输入的blocks块。
conv = ASCII 把EBCDIC码转换为ASCIl码。
conv = ebcdic 把ASCIl码转换为EBCDIC码。
conv = ibm 把ASCIl码转换为alternate EBCDIC码。
conv = block 把变动位转换成固定字符。
conv = ublock 把固定位转换成变动位。
conv = ucase 把字母由小写转换为大写。
conv = lcase 把字母由大写转换为小写。
conv = notrunc 不截短输出文件。
conv = swab 交换每一对输入字节。
conv = noerror 出错时不停止处理。
conv = sync 把每个输入记录的大小都调到ibs的大小(用NUL填充)。

使用实例

查看dd版本

1
2
3
4
5
6
7
8
[root@ceph-node3 ~]# dd --version
dd (coreutils) 8.22
Copyright (C) 2013 Free Software Foundation, Inc.
许可证:GPLv3+:GNU 通用公共许可证第3 版或更新版本<http://gnu.org/licenses/gpl.html>。
本软件是自由软件:您可以自由修改和重新发布它。
在法律范围内没有其他保证。

由Paul Rubin、David MacKenzie 和Stuart Kemp 编写。

把系统的一个文件cp成到另一个新文件

1
2
3
4
5
6
7
8
[root@ceph-node3 ~]# ls
anaconda-ks.cfg ceph_path initial-setup-ks.cfg node-v11.0.0 node-v11.0.0.tar.gz workspace 公共 模板 视频 图片 文档 下载 音乐 桌面
[root@ceph-node3 ~]# dd if=/root/anaconda-ks.cfg of=/root/he.txt
记录了3+1 的读入
记录了3+1 的写出
1693字节(1.7 kB)已复制,0.00023223 秒,7.3 MB/秒
[root@ceph-node3 ~]# ls
anaconda-ks.cfg ceph_path he.txt initial-setup-ks.cfg node-v11.0.0 node-v11.0.0.tar.gz workspace 公共 模板 视频 图片 文档 下载 音乐 桌面

创建一个100M的空文件

1
2
3
4
[root@ceph-node3 ~]# dd if=/dev/zero of=he.txt bs=100M count=1
记录了1+0 的读入
记录了1+0 的写出
104857600字节(105 MB)已复制,0.0949458 秒,1.1 GB/秒

常用知识

1
2
3
4
/dev/null,外号叫无底洞,你可以向它输出任何数据,它通吃,并且不会撑着!
/dev/zero,是一个输入设备,你可你用它来初始化文件。
/dev/null——它是空设备,也称为位桶(bit bucket)。任何写入它的输出都会被抛弃。如果不想让消息以标准输出显示或写入文件,那么可以将消息重定向到位桶。
/dev/zero——该设备无穷尽地提供0,可以使用任何你需要的数目——设备提供的要多的多。他可以用于向设备或文件写入字符串0。