dd命令详解及实战应用

dd简述

dd在linux中是 一个强大的命令,常用于拷贝大量数据,测试读写效能 ,清空硬盘数据(慎用),不仅如此,由于dd 允许以二进制方式读写,所以特别适合在原始设备上输入、输出。

dd与cp的区别

这里有必要说明一下,两个命令都可用于拷贝,但是级别却完全不一样:cp是文件级别的读取方式,而dd更底层,可以数据块级别去读取硬盘,由此可看出在效率上显然dd更胜一筹;其次在较大数据拷贝中,cp是复制文件(其本质是新建),过程中经由操作系统处理,最终存放在硬盘上的数据是随机分散的,并不连续,而dd的拷贝可以做到在硬盘上数据的存储是连续的,其它不再枚举,总之dd在较大数据量的备份场景,更加高效

dd常用参数

if=inputfile:指定源文件,即指定输入文件、缺省为标准输入,在LINUX中一切皆文件,因此可指定一些特殊的文件(如设备文件)用于特殊用途

of=outputfile:指定目标文件,即指定输出文件,缺省为标准输出

bs=N bytes:同时指定读入/输出的块大小为N个字节,N为数字

count=N blocks:指定拷贝的块数量,块大小由bs指定。N为数字

通常最常用的参数也就这四个,事实上dd支持的参数非常之多,在此不过多枚举(实际应用不是很多,需用到时在MAN下吧

命令格式及常见用法

1.备份整个盘(分区)的数据:dd if=/dev/sda of=/dev/sdb

2.备份整个盘(分区)数据到某个文件:dd if=/dev/sda of=/path/to/filename

*将文件内容还原到某硬盘:dd if=srcfile of=/dev/sda

3.备份整个盘(分区)并压缩后保存至指定路径:dd if=/dev/sda | gzip > /path/to/filename.gz

*将备份的压缩文件还原到硬盘{分区}:gzip -dc /path/to/filename.gz | dd of=/dev/sda

4.备份与还原MBR:dd if=/dev/sda of=/path/to/filename bs=512 count=1

*bs用于指定备份的块大小,单位为字节,这里表示将sda的第一个扇区(恰好512字节),也就是MBR存放的位置;count用于指定块的数量

*还原:dd if=/path/to/filename of=/dev/sdb

5.拷贝内存内容到硬盘:dd if=/dev/mem of=/path/to/filename.mem bs=1024

6.拷贝光盘内容到硬盘:dd if=/dev/cdrom of=/path/to/filename.iso

7.增加swap分区文件大小

①创建一个相应大小的文件(空白文件,这里可以使用/dev/zero填充)

dd if=/dev/zero of=/swapfile bs=1024 count=100000;(根据需要自行调整大小,此处为100M)

②将此前创建的文件识别为swap文件

mkswap /swapfile

③启用创建好的SWAP文件

swapon /swapfile

④挂载SWAP,mount挂载重启后会失效,这里设定为自定挂载,打开/etc/fstab文件新增一行

/swapfile swap  swap default 0 0至此,完成swap大小的调整

8.销毁硬盘数据(慎用)

dd if=/dev/urandom of=/dev/sdb ( 这里利用随机数填充硬盘,某些特殊场合可以用来销毁数据)

9.测试硬盘读写速度

①dd if=/dev/zero bs=1024 count=1000000  of=/path/to/test.1GB 测试写入速度,通过命令执行时间计算

②dd if=/path/to/test.1GB bs=64K | dd of=/dev/null 测试读取速度,通过命令执行时间计算

10.测试硬盘效能最佳块大小

 dd if=/dev/zero bs=1024 count=1000000 of=/path/to/test.1GB

 dd if=/dev/zero bs=2048 count=500000 of=/path/to/test.1GB
 dd if=/dev/zero bs=4096 count=250000 of=/path/to/test.1GB
 dd if=/dev/zero bs=8192 count=125000 of=/path/to/test.1GB

*通过各命令执行的时间可大概测试最佳块大小

11.某种程度上修复硬盘

dd if=/dev/sda of=/dev/sda

总结:dd命令很好很强大



原创文章,作者:sevenyellow,如若转载,请注明出处:http://www.178linux.com/72551

(0)
sevenyellowsevenyellow
上一篇 2017-04-04 22:36
下一篇 2017-04-04 23:54

相关推荐

  • Linux文件系统权限详解

    一、综述 在用户和组的管理中介绍了Linux系统是用户多任务的分时操作系统,这意味着同时可以有多人在同一台pc上进行不同的操作。为了能够保护每个用户的数据安全,针对不同的用户设置相应的权限是非常重要的。 Linux文件系统权限主要针对三类用户: 文件的所有者: owner,用u标识 文件的所有组:group,用g标识 其他人: other,用o标识。不包含在…

    Linux干货 2016-08-04
  • 系统管理之系统启动及内核编译

    CentOS 5和6的启动流程服务管理Grub管理自制Linux启动排错编译安装内核 系统启动流程:  POST –> 读取BootSequence (BIOS),决定引导次序 –>读取引导设备的Bootloader(MBR grubstage1–>stage1.5/boot…

    Linux干货 2016-09-13
  • ansible的入门使用手册

    ansible1

    2018-01-15
  • 用户管理命令之NBA版

    用户管理命令之NBA版 本文纯属扯淡,如有不严谨之处,还请海涵。 1 groupadd 作用:创建一个属组 格式:groupadd [选项] 属组名 选项: -:选项为空 创建新属组 -g:指定组GID,默认是GID+1 实例 1.1 添加属组team,指定组ID为1111      groupadd -g …

    Linux干货 2017-03-27
  • N25_第十一周的作业

    1、详细描述一次加密通讯的过程,结合图示最佳。 2、描述创建私有CA的过程,以及为客户端发来的证书请求进行办法证书。 3、描述DNS查询过程以及DNS服务器类别。          第一段:主机到运营商的DNS服务器(递归)    &nbs…

    Linux干货 2017-02-22
  • Linux系统下的bonding设置

    bonding多个物理网卡聚合成一个虚拟网卡     Bonding,其原理是讲多个物理网卡聚合成一个虚拟网卡,一张网卡正常工作,其余网卡作为备用,每隔一段时间(miimon=毫秒),向正常工作的网卡发一状态询问,若没回复,则认为其运行失败,然后就会启用备用网卡,但是IP地址不会改变。   &nbs…

    Linux干货 2016-09-07

评论列表(1条)

  • renjin
    renjin 2017-04-05 14:30

    对dd命令的用法写的很详细,可以适当的插入几张图片,注意一下排版。这样会好很多