Linux 下的dd命令使用详解

dd命令
dd:用指定大小的块拷贝一个文件,并在拷贝的同时进行指定的转换。
注意:指定数字的地方若以下列字符结尾,则乘以相应的数字:b=512;c=1;k=1024;w=2

参数注释:
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)字符补齐。

案例:
一、测试写速度:

[root@localhost ~]# time dd if=/dev/zero of=/tmp/test bs=8k count=1000000
dd: error writing ‘/tmp/test’: No space left on device
774060+0 records in
774059+0 records out
6341095424 bytes (6.3 GB) copied, 14.6923 s, 432 MB/s

real	0m14.694s
user	0m0.044s
sys	0m6.913s
[root@localhost ~]# ll /tmp/test -h
-rw-r--r-- 1 root root 6.0G Nov 14 14:27 /tmp/test

二、测试读速度:

[root@localhost ~]# time dd if=/tmp/test of=/dev/null bs=8k
774059+1 records in
774059+1 records out
6341095424 bytes (6.3 GB) copied, 6.8682 s, 923 MB/s

real	0m6.876s
user	0m0.082s
sys	0m6.098s

三、测试读写速度:

time dd if=/tmp/test of=/var/test bs=64k

注:参数说明
①、time 有计时作用,dd 用于复制,从 if 读出,写到 of;

②、if=/dev/zero 不产生 IO,因此可以用来测试纯写速度;

③、同理 of=/dev/null 不产生 IO,可以用来测试纯读速度;

④、将/tmp/test 拷贝到/var 则同时测试了读写速度;

⑤、bs 是每次读或写的大小,即一个块的大小,count 是读写块的数量。

四:有一个二进制文件fileA。现在想从第64个字节位置开始读取,需要读取的大小是128Byts。又有fileB, 想把上面读取到的128Bytes写到第32个字节开始的位置,替换128Bytes,实现如下

dd if=fileA of=fileB bs=1 count=128 skip=63 seek=31 conv=notrunc

dd if=f1.txt of=f2.txt bs=1 count=2 skip=3 seek=4   conv=notrunc ===>  不截断输出

五:创建空洞文件或稀疏文件 不占空间

dd if=/dev/zero  of=/data/bigfile  bs=1M count=0 seek=1024
[root@localhost ~]# dd if=/dev/zero  of=/data/bigfile  bs=1M count=0 seek=1024
0+0 records in
0+0 records out
0 bytes (0 B) copied, 0.000276263 s, 0.0 kB/s

[root@localhost ~]# ll /data/bigfile -h
-rw-r--r-- 1 root root 1.0G Nov 14 14:43 /data/bigfile
注:使用df查看显示不占用磁盘空间

六:备份MBR的分区表

[root@localhost ~]# dd if=/dev/sda  of=/data/1.img count=64 bs=1 skip=446
64+0 records in
64+0 records out
64 bytes (64 B) copied, 0.000382025 s, 168 kB/s
[root@localhost ~]# hexdump /data/1.img 
0000000 2080 0021 9f83 1906 0800 0000 4000 0006
0000010 9f00 1907 fe8e ffff 4800 0006 b800 0279
0000020 0000 0000 0000 0000 0000 0000 0000 0000
*
0000040

根据备份的分区表恢复MBR分区表
[root@localhost ~]# dd if=/data/1.img of=/dev/sda count=64 bs=1 seek=446
64+0 records in
64+0 records out
64 bytes (64 B) copied, 0.000220463 s, 290 kB/s
[root@localhost ~]# hexdump /dev/sda -n 512

七:备份实例

1.将本地的/dev/hdb整盘备份到/dev/hdd
#dd if=/dev/hdb of=/dev/hdd
2.将/dev/hdb全盘数据备份到指定路径的image文件
#dd if=/dev/hdb of=/root/image
3.将备份文件恢复到指定盘
#dd if=/root/image of=/dev/hdb
4.备份/dev/hdb全盘数据,并利用gzip工具进行压缩,保存到指定路径
#dd if=/dev/hdb | gzip > /root/image.gz
5.将压缩的备份文件恢复到指定盘
#gzip -dc /root/image.gz | dd of=/dev/hdb
posted @   咚咚小孩  阅读(2153)  评论(0编辑  收藏  举报
编辑推荐:
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
阅读排行:
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 零经验选手,Compose 一天开发一款小游戏!
· 一起来玩mcp_server_sqlite,让AI帮你做增删改查!!
点击右上角即可分享
微信分享提示