linux中dd命令写⼊数据,Linux中dd命令的⽤法dd命令: convert and copy a file
⽤法:dd if=/PATH/FROM/SRC of=/PATH/TO/DEST
bs=#: block size, 复制单元⼤⼩
count=#:复制多少个bs
of=file 写到所命名的⽂件⽽不是到标准输出
if=file 从所命名⽂件读取⽽不是从标准输⼊
bs=size 指定块⼤⼩(既是ibs也是obs)
ibs=size ⼀次读size个byte
obs=size ⼀次写size个byte
cbs=size ⼀次转化size个byte
skip=blocks 从开头忽略blocks个ibs⼤⼩的块
seek=blocks 从开头忽略blocks个obs⼤⼩的块
count=n 只拷贝n个记录
⽤指定的参数转换⽂件:conv=conversion[,]
转换参数:ascii 转换 EBCDIC 为 ASCII
ebcdic 转换 ASCII 为 EBCDIC
block 转换⼀⾏数据为长度为 cbs 的记录,不⾜部分⽤空格填充。
unblock 替代cbs长度的每⼀⾏尾的空格为新⾏
lcase 把⼤写字符转换为⼩写字符
ucase 把⼩写字符转换为⼤写字符
nocreat 不创建输出⽂件
noerror 出错时不停⽌
notrunc 不截断输出⽂件
sync 把每个输⼊块填充到ibs个字节,不⾜部分⽤空(NUL)字符补齐。
备份:dd if=/dev/sdx of=/dev/sdy
将本地的/dev/sdx整盘备份到/dev/sdydd if=/dev/sdx of=/path/to/image
将/dev/sdx全盘数据备份到指定路径的image⽂件dd if=/dev/sdx | gzip >/path/
备份/dev/sdx全盘数据,并利⽤gzip⼯具进⾏压缩,保存到指定路径。
恢复:dd if=/path/to/image of=/dev/sdx
将备份⽂件恢复到指定盘gzip -dc /path/ | dd of=/dev/sdx
将压缩的备份⽂件恢复到指定盘。
拷贝内存资料到硬盘:dd if=/dev/mem of=/root/mem.bin bs=1024
将内存⾥的数据拷贝到root⽬录下的mem.bin⽂件。
从光盘拷贝iso镜像:dd if=/dev/cdrom of=/root/cd.iso
拷贝光盘数据到root⽂件夹下,并保存为cd.iso⽂件。
销毁磁盘数据:dd if=/dev/urandom of=/dev/sda1
利⽤随机的数据填充硬盘,在某些必要的场合可以⽤来销毁数据。执⾏此操作以后,/dev/ sda1将⽆法挂载,创建和拷贝操作⽆法执⾏。
得到最恰当的block size:dd if=/dev/zero bs=1024 count=1000000
of=/root/1Gb.file
dd if=/dev/zero bs=2048 count=500000
of=/root/1Gb.file
dd if=/dev/zero bs=4096 count=250000
of=/root/1Gb.file
linux命令查看文件夹大小通过⽐较dd指令输出中所显⽰的命令执⾏时间,即可确定系统最佳的block size⼤⼩:
测试硬盘读写速度:dd if=/dev/zero of=/root/1Gb.file bs=1024 count=1000000
dd if=/root/1Gb.file bs=64k | dd of=/dev/null
通过上两个命令输出的执⾏时间,可以计算出测试硬盘的写/读/速度。
修复硬盘:dd if=/dev/sda of=/dev/sda
当硬盘较长时间(⽐如1,2年)放置不使⽤后,磁盘上会产⽣消磁点。当磁头读到这些区域时会遇到困难,并可能导致I/O错误。当这种情况影响到硬盘的第⼀个扇区时,可能导致硬盘报废。上边的命令有可能使这些数据起死回⽣,且这个过程是安全⾼效的。
⽰例:
1.备份MBR:[root@anonymous ~]#dd if=/dev/sda1 of=/tmp/mbr.bak bs=512
count=11+0 records in
1+0 records out
512 bytes (512 B) copied, 0.000160395 s, 3.2 MB/s
2.有⼀个⼤于2K的⼆进制⽂件fileA。现在想从第64个字节位置开始读取,需要读取的⼤⼩是128Byts。⼜有fileB, 想把上⾯读取到的
128Bytes写到第32个字节开始的位置,替换128Bytes,请问如何实现?
[root@anonymous ~]#dd if=fileA of=fileB bs=1 count=128 skip=63 seek=31 conv=notrunc
128+0 records in
128+0 records out
128 bytes (128 B) copied, 0.000421017 s, 304 kB/s
3.创建⼀个2G的⽂件系统,块⼤⼩为2048byte,预留1%可⽤空间,⽂件系统ext4,卷标为TEST,要求此分区开机后⾃动挂载⾄/test⽬录,且默认有acl挂载选项
[root@anonymous ~]#dd if=/dev/zero of=test bs=1M count=2048
2048+0 records in
2048+0 records out
2147483648 bytes (2.1 GB) copied, 121.521 s, 17.7 MB/s
[root@anonymous ~]#4 -b 2048 -L 'TEST' -m 1 test
mke2fs 1.41.12 (17-May-2010)
test is not a block special device.
Proceed anyway? (y,n) y
Filesystem label=TEST
OS type: Linux
Block size=2048 (log=1)
Fragment size=2048 (log=1)
Stride=0 blocks, Stripe width=0 blocks
131072 inodes, 1048576 blocks
10485 blocks (1.00%) reserved for the super user
First data block=0
Maximum filesystem blocks=537919488
64 block groups
16384 blocks per group, 16384 fragments per group
2048 inodes per group
Superblock backups stored on blocks:
16384, 49152, 81920, 114688, 147456, 409600, 442368, 802816
Writing inode tables: done
Creating journal (32768 blocks): done
Writing superblocks and filesystem accounting information: done
This filesystem will be automatically checked every 35 mounts or
180 days, whichever comes first. Use tune2fs -c or -i to override.
[root@anonymous ~]#tune2fs -o acl test
tune2fs 1.41.12 (17-May-2010)
[root@anonymous ~]#echo '/root/test /mnt/test ext4 defaults 0 0' >> /etc/fstab [root@anonymous ~]#echo '/root/test /mnt/test ext4 defaults,loop 0 0' >> /etc/fstab [root@anonymous ~]#mount -a
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论