本文摘自PHP中文网,作者黄舟,侵删。
dd命令用指定大小的块拷贝一个文件,并在拷贝的同时进行指定的转换。下面这篇文章主要给大家介绍了关于Linux中dd命令使用的相关资料,对大家具有一定的参考学习价值,需要的朋友们下面来一起看看吧。本文主要给大家介绍了关于Linux中dd命令使用的相关内容,分享出来供大家参考学习,下面来看看详细的介绍:
一、Linux dd命令用指定大小的块拷贝一个文件,并在拷贝的同时进行指定的转换。
使用方法:dd [OPERAND]
参数注释:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 | bs=BYTES read and write BYTES bytes at a time (also see ibs=,obs=)
cbs=BYTES convert BYTES bytes at a time
conv=CONVS convert the file as per the comma separated symbol list
count=N copy only N input blocks
ibs=BYTES read BYTES bytes at a time (default: 512)
if=FILE read from FILE instead of stdin(默认为标准输入)
iflag=FLAGS read as per the comma separated symbol list
obs=BYTES write BYTES bytes at a time (default: 512)
of=FILE write to FILE instead of stdout(默认为标准输出)
oflag=FLAGS write as per the comma separated symbol list
seek=BLOCKS skip BLOCKS obs-sized blocks at start of output
skip=BLOCKS skip BLOCKS ibs-sized blocks at start of input
status=WHICH WHICH info to suppress outputting to stderr;
'noxfer' suppresses transfer stats, 'none' suppresses all
|
CONVS的可选参数
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 | ascii from EBCDIC to ASCII
ebcdic from ASCII to EBCDIC
ibm from ASCII to alternate EBCDIC
block pad newline-terminated records with spaces to cbs-size
unblock replace trailing spaces in cbs-size records with newline
lcase change upper case to lower case
nocreat do not create the output file
excl fail if the output file already exists
notrunc do not truncate the output file
ucase change lower case to upper case
sparse try to seek rather than write the output for NUL input blocks
swab swap every pair of input bytes
noerror continue after read errors
sync pad every input block with NULs to ibs-size; when used
with block or unblock, pad with spaces rather than NULs
fdatasync physically write output file data before finishing
fsync likewise, but also write metadata
|
FLAGS的可选参数
1 2 3 4 5 6 7 8 9 10 11 | append append mode (makes sense only for output; conv=notrunc suggested)
direct use direct I/O for data
directory fail unless a directory
dsync use synchronized I/O for data
sync likewise, but also for metadata
fullblock accumulate full blocks of input (iflag only)
nonblock use non-blocking I/O
noatime do not update access time
noctty do not assign controlling terminal from file
nofollow do not follow symlinks
count_bytes treat 'count=N' as a byte count (iflag only)
|
注意:指定数字的地方若以下列字符结尾,则乘以相应的数字:
1 2 3 | c =1, w =2, b =512, kB =1000, K =1024, MB =1000*1000, M =1024*1024, xM =M
GB =1000*1000*1000, G =1024*1024*1024, and so on for T, P, E, Z, Y
|
二、使用实例
1、将本地的/dev/hdb整盘备份到/dev/hdd
1 | dd if = /dev/hdb of= /dev/hdd
|
2、将/dev/hdb全盘数据备份到指定路径的image文件
1 | dd if = /dev/hdb of= /root/image
|
3、备份/dev/hdb全盘数据,并利用gzip工具进行压缩,保存到指定路径
1 | dd if = /dev/hdb | gzip > /root/image .gz
|
4、把一个文件拆分为3个文件
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 | [Oracle@rhel6 ~]$ ll db1_db_links.sql
-rw-r--r-- 1 oracle oinstall 2344 Nov 21 10:39 db1_db_links.sql
[oracle@rhel6 ~]$ dd if =db1_db_links.sql of=dd01.sql bs=1k count=1
1+0 records in
1+0 records out
1024 bytes (1.0 kB) copied, 4.5536e-05 s, 22.5 MB /s
[oracle@rhel6 ~]$ dd if =db1_db_links.sql of=dd02.sql bs=1k count=1 skip=1
1+0 records in
1+0 records out
1024 bytes (1.0 kB) copied, 0.000146387 s, 7.0 MB /s
[oracle@rhel6 ~]$ dd if =db1_db_links.sql of=dd03.sql bs=1k count=1 skip=2
0+1 records in
0+1 records out
296 bytes (296 B) copied, 0.000204216 s, 1.4 MB /s
[oracle@rhel6 ~]$ ll dd *sql
-rw-r--r-- 1 oracle oinstall 1024 May 20 14:58 dd01.sql
-rw-r--r-- 1 oracle oinstall 1024 May 20 14:58 dd02.sql
-rw-r--r-- 1 oracle oinstall 296 May 20 14:58 dd03.sql
|
5、把拆分出的文件合并为1个
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 | [oracle@rhel6 ~]$ dd of=1.sql if =dd01.sql
2+0 records in
2+0 records out
1024 bytes (1.0 kB) copied, 0.000176 s, 5.8 MB /s
[oracle@rhel6 ~]$ dd of=1.sql if =dd02.sql bs=1k seek=1
1+0 records in
1+0 records out
1024 bytes (1.0 kB) copied, 0.000124038 s, 8.3 MB /s
[oracle@rhel6 ~]$ dd of=1.sql if =dd03.sql bs=1k seek=2
0+1 records in
0+1 records out
296 bytes (296 B) copied, 0.00203881 s, 145 kB /s
[oracle@rhel6 ~]$ diff 1.sql db1_db_links.sql
[oracle@rhel6 ~]$
|
6、在输出文件中指定的位置插入数据,而不截断输出文件
需要使用conv=notrunc
参数
1 | [oracle@rhel6 ~]$ dd if =2.sql of=1.sql bs=1k seek=1 count=2 conv=notrunc
|
总结
以上就是Linux中关于dd命令的使用实例教程的详细内容,更多文章请关注木庄网络博客!
相关阅读 >>
Linux下如何杀死一个进程
如何使用云助手自动化管理实例
让Linux不区分大小写
Linux与windows文件显示乱码
Linux中汉字显示乱码怎么办
如何快速简单的优化快照使用成本
Linux 如何查看版本
Linux怎么挂载
【 Linux】?netdata1.25.0发布!实时性能和健康监测系统
让Linux不区分大小写
更多相关阅读请进入《Linux》频道 >>
转载请注明出处:木庄网络博客 » Linux中关于dd命令的使用实例教程