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

相关推荐

  • 【盘点】2017年9-11月运维大会(时间+地点)

    到底未来的运维模式是什么?如今运维人员面临着怎样的转变? 活动家为您精心挑选整理了9-11月七场运维大会希望本文能帮您! CNUTCon 全球运维技术大会2017 大会简介: CNUTCon全球运维技术大会是由InfoQ主办的运维&容器技术盛会。大会为期2天,主要面向各行业对运维&容器技术感兴趣的中高端技术人员。秉承着“同步前沿技术、共享实战…

    2017-08-31
  • 通过fast-cgi方式在三台主机部署phpwind并设置为https站点

    通常来说httpd用来处理静态的网页请求,动态的资源请求以前是通过CGI的方式进行处理的,但是CGI的方式的处理过程是这样:有动态资源请求,服务器会fork一个CGI进程进行资源处理,处理完成后这个进程会退出,当再有新的动态资源请求,又会fork一个进程,这样的效率是很低的。后来就有了通过加载php模块的方式,即:httpd服务器启动之后会自动加载php动态…

    2017-06-04
  • 2016.08.04学习笔记

    文本管理工具     1.cat:查看文件,读取键盘输入         -A:查看文件所有信息         -n:显示行数   &nb…

    Linux干货 2016-08-08
  • Linux磁盘和文件系统管理进阶(swap、磁盘配额、RAID、LVM、btrfs)

    概述:     上篇已经介绍了一些磁盘和文件系统管理的基础概念,对磁盘的硬件构造,文件系统的基础概念部分有了一个大致的了解。本篇就分享一些关于磁盘和文件系统管理的一些高级应用,具体包含:     1、swap交换分区的管理     2、挂载…

    Linux干货 2016-08-30
  • find命令简单总结

     find     字符串类查询:            -type   //根据文件类型查找       &…

    Linux干货 2015-09-14
  • gawk

    简介     AWK是一种优良的文本处理工具。它不仅是 Linux 中也是任何环境中现有的功能最强大的数据处理引擎之一。AWK 提供了极其强大的功能:可以进行样式装入、流控制、数学运算符、进程控制语句甚至于内置的变量和函数。它具备了一个完整的语言所应具有的几乎所有精美特性。实际上 AWK 的确拥有自…

    Linux干货 2016-03-25

评论列表(1条)

  • renjin
    renjin 2017-04-05 14:30

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