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
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 零经验选手,Compose 一天开发一款小游戏!
· 一起来玩mcp_server_sqlite,让AI帮你做增删改查!!