首页 > 编程知识 正文

dd脚本是什么意思,dd命令的用法正确的是

时间:2023-05-03 22:56:49 阅读:151888 作者:4006

dd命令位于测试写

超高速缓存

ddif=/dev/zero of=/info kist/test/data1 bs=1mcount=50000 (表示后台进行) )

但是缓存

ddif=/dev/zero of=/info kist/test/data2bs=1mcount=100000 oflag=direct

测试读

测试磁盘的读取能力

timed dif=/dev/sdb of=/dev/null bs=4k

dd命令检查dd详细信息是一个非常有用的命令,用于在Linux/UNIX上以指定大小的块复制文件,并在复制的同时进行指定的转换。

名称: dd

使用权限:的所有用户dd命令在manual中的定义是convert and copy a file

使用方法:

dd [option]

如果你想在线看manual,可以试试:

DDhelp

或者

info dd

如果你想看这个版本:

DDversion

输入或输出

dd if=[STDIN] of=[STDOUT]

强制输入或输出的Size是多少字节

bs : DD-IBS=[ byte ]-OBS=[ size ]

一次只让你做几个Bytes

cbs=BYTES

跳过一段后输出

seek=BLOCKS

跳过一层再输入

skip=BLOCKS

当然可以拿着这个制作方便的复印CD。 (注意,你的光盘是标准的iso9660格式。 可以那样做哦。 )

dd if=/dev/cdrom of=cdrom.iso

其中if后面和of后面的内容会根据你的需求进行调整。

给系统这个命令就可以烧掉:

cdrecord -v cdrom.iso

因为这不是cdrecord的故事,所以以上命令最简单,但不一定适合硬件环境……

功能:可以将指定的输入文件复制到指定的输出文件,并在复制过程中进行格式转换。 通过此命令可以实现DOS下diskcopy命令的作用。 用dd命令将软盘上的数据写入硬盘的一个注册文件,将该注册文件写入第二张软盘,完成光盘的功能。 需要注意的是,使用rm命令删除硬盘上的注册文件。 默认情况下使用标准输入文件和标准输出文件。

语法: dd [选项] if=输入文件(或设备名称)。

of=输出文件(或设备名称)。

ibs=bytes一次读取bytes字节,即读取到缓冲区中的字节数。

skip=blocks跳过读取缓冲区开头的ibs*blocks块。

OBS=bytesbytes一次写入的字节数,即写入缓冲区的字节数。

bs=bytes同时设置读/写缓冲区的字节数。 这与同时设置ibs和obs相同。

cbs=byte一次转换bytes字节。

count=blocks仅复制输入的blocks块。

conv=ASCII将EBCDIC代码转换为ASCIl代码。

conv=EBCDIC将ASCIl代码转换为ebcdic代码。

conv=ibm将ASCIl代码转换为备用ebcdic代码。

将conv=block变动位转换为固定字符。

conv=ublock将固定位转换为变动位。

conv=ucase将字母从小写转换为大写。

conv=lcase将字母从大写转换为小写。

conv=notrunc不会截断输出文件。

conv=swab交换每对输入字节。

发生conv=noerror错误时不停止处理。

conv=sync将每个输入记录的大小设置为ibs的大小(用NUL填充)。

例1 )将一张软盘的内容复制到另一张软盘上,用/tmp作为临时存储区。 将源磁盘插入驱动器,然后输入以下命令:

$ dd if=/dev/fd0 of=/tmp/tmpfile

复制完成后,从驱动器中取出源磁盘,插入目标磁盘,然后输入命令。

$ dd if=/tmp/tmpfile of=/dev/fd0

软盘复制完成后,必须删除临时文件。

$ rm /tmp/tmpfile

例2 )将net.i文件写入软盘,并设置读/写缓冲区的数量。

(注意:软盘的内容将被完全覆盖)

$ dd if=net.i of=/dev/fd0 bs=16384

例3 )将文件sfile复制到文件dfile。

$dd if=sfile of=dfile

示例创建100米的空文件

ddif=/dev/zero of=hello.txt bs=100 mcount=1

/dev/null,绰号是无底洞,你能向它输出什么样的数据,它吃了,撑不下去!

/dev/zero,是

一个输入设备,你可你用它来初始化文件。
/dev/null——它是空设备,也称为位桶(bit bucket)。任何写入它的输出都会被抛弃。如果不想让消息以标准输出显示或写入文件,那么可以将消息重定向到位桶。
/dev/zero——该设备无穷尽地提供0,可以使用任何你需要的数目——设备提供的要多的多。他可以用于向设备或文件写入字符串0。
$ dd if=/dev/zero of=./test.txt bs=1k count=1
$ ls -l
total 4
-rw-r–r– 1 oracle dba 1024 Jul 15 16:56 test.txt
eg:
$ find / -name access_log 2>/dev/null
创建特定大小文件最简单的方法是使用 dd 命令。
dd if=“inputFileName” of=”outFileName” bs=”块大小” count=“块个数”
块大小可以使用各种计量单位
字节(1B) – c 字(2B) – w
块(512B) – b 千字节(1024B) – k
兆字节(1024K) – M 吉字节(1024M) – G

例:
dd if=/dev/zero of=test.file bs=1M count=10
在当前文件夹下创建一个大小为10M的文件test.file 内容全为0
/dev/zero 是一个字符设备,它会不断返回0值字节(/0).
如果不指定输入参数(if),默认情况会从stdin读取输入。如果不指定输出参数(of),默认情况会将stdout作为输出。
也可用 dd 命令来传输大量数据来测试内存的操作速度。

$ dd if=/dev/zero of=./testmm.file bs=10M count=10

记录了10+0 的读入
记录了10+0 的写出
104857600字节(105 MB)已复制,0.577581 秒,182 MB/秒

$ ll -h |grep ‘testmm.file’
-rw-rw-r–. 1 itudu itudu 100M 7月 16 18:14 testmm.file

文件类型:
一般文件: –
目录文件: d
字符设备: c
块设备: b
链接文件: l
套接字文件: s
管道文件: p

目录的读、写、执行权限意义:
读权限:允许读取目录中文件和子目录的列表
写权限:允许在目录中新建和删除文件或子目录
执行权限:可以访问目录中的文件和子目录

注意:dd 只能提供一个大概的测试结果,而且是连续 I/O 而不是随机 I/O,理论上文件规模越大,测试结果越准确。 同时,iflag/oflag 提供 direct 模式,direct 模式是把写入请求直接封装成 I/O 指令发到磁盘,非 direct 模式只是把数据写入到系统缓存就认为 I/O 成功,并由操作系统决定缓存中的数据什么时候被写入磁盘。

linux下dd命令详解

名称: dd
使用权限: 所有使用者
manpage 定义: convert and copy a file
使用方式:
dd [option]
dd –help
info dd
dd –version
输入或输出
dd if=[STDIN] of=[STDOUT]
强迫输入或输出的Size为多少Bytes
bs: dd -ibs=[BYTE] -obs=[SIZE]
语法:dd [选项]
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填充)。
noerror
出错时不停止。
notrunc
不截短输出文件。
sync 把每个输入块填充到ibs个字节,不足部分用空(NUL)字符补齐。
—————————————————————-
认识下两个”伪文件”
/dev/null
位桶文件(bit bucket),就是我们常说的空文件。是一个输出设备。
任何写入它的输出都会被抛弃。如果不想让消息以标准输出显示或写入文件,那么可以将消息重定向到位桶。把/dev/null看作”黑洞”. 它非常等价于一个只写文件. 所有写入它的内容都会永远丢失. 而尝试从它那儿读取内容则什么也读不到. 然而, /dev/null对命令行和脚本都非常的有用.
/dev/zero
是一个输入设备,你可你用它来初始化文件。
该设备无穷尽地提供0(是ASCII 0 就是NULL),可以使用任何你需要的数目——设备提供的要多的多。他可以用于向设备或文件写入NULL。
像/dev/null一样, /dev/zero也是一个伪文件, 但它实际上产生连续不断的null的流(二进制的零流,而不是ASCII型的). 写入它的输出会丢失不见, 而从/dev/zero读出一连串的null也比较困难, 虽然这也能通过od或一个十六进制编辑器来做到. /dev/zero主要的用处是用来创建一个指定长度用于初始化的空文件,就像临时交换文件.
————————————————————–
使用dd来测试硬盘读写速度
dd只能提供一个大概的测试结果,而且是连续IO 而不是随机IO ,理论上文件规模越大,测试结果越准确。

读性能测试

#time dd iflag=direct,nonblock if=/dev/sda2 of=/dev/null bs=8k count=8388608
因为/dev/sda2是一个物理分区,对它的读取会产生IO,/dev/null是伪设备,相当于黑洞,of到该设备不会产生IO,所以,这个命令的IO只发生在/dev/sdb1上,也相当于测试磁盘的读能力。
写测试
#time dd oflag=direct,nonblock if=/dev/zero of=/opt/iotest bs=8k count=8388608
因为/dev/zero是一个伪设备,它只产生空字符流,对它不会产生IO,所以,IO都会集中在of文件中,of文件只用于写,所以这个命令相当于测试磁盘的写能力。
读写测试
#time dd iflag=direct,nonblock oflag=direct,nonblock if=/dev/sda2 of=/opt/iotest bs=8k count=8388608

注:bs是一次io读的规模,理论上bs越大,所测得性能越高
count是读多少个”bs”,也可以写成count=16G
规避掉文件系统cache,直接读写,不使用buffer cache
iflag=direct,nonblock
oflag=direct,nonblock
iflag=cio
oflag=cio
direct 模式就是把写入请求直接封装成io 指令发到磁盘
非direct 模式,就把数据写入系统缓存,然后就认为io 成功,并由操作系统决定缓存中的数据什么时候被写入磁盘

版权声明:该文观点仅代表作者本人。处理文章:请发送邮件至 三1五14八八95#扣扣.com 举报,一经查实,本站将立刻删除。