dd命令
本文轉自:https://www.cnblogs.com/ginvip/p/6370836.html
一:dd命令
dd:用指定大小的塊拷貝一個檔案,並在拷貝的同時進行指定的轉換。
注意:指定數字的地方若以下列字元結尾,則乘以相應的數字:b=512;c=1;k=1024;w=2
引數註釋:
- if=檔名:輸入檔名,預設為標準輸入。即指定原始檔。< if=input file >
- of=檔名:輸出檔名,預設為標準輸出。即指定目的檔案。< of=output file >
- ibs=bytes:一次讀入bytes個位元組,即指定一個塊大小為bytes個位元組。
obs=bytes:一次輸出bytes個位元組,即指定一個塊大小為bytes個位元組。
bs=bytes:同時設定讀入/輸出的塊大小為bytes個位元組。 - cbs=bytes:一次轉換bytes個位元組,即指定轉換緩衝區大小。
- skip=blocks:從輸入檔案開頭跳過blocks個塊後再開始複製。
- seek=blocks:從輸出檔案開頭跳過blocks個塊後再開始複製。
注意:通常只用當輸出檔案是磁碟或磁帶時才有效,即備份到磁碟或磁帶時才有效。 - count=blocks:僅拷貝blocks個塊,塊大小等於ibs指定的位元組數。
- conv=conversion:用指定的引數轉換檔案。
- ascii:轉換ebcdic為ascii
- ebcdic:轉換ascii為ebcdic
- ibm:轉換ascii為alternate ebcdic
- block:把每一行轉換為長度為cbs,不足部分用空格填充
- unblock:使每一行的長度都為cbs,不足部分用空格填充
- lcase:把大寫字元轉換為小寫字元
- ucase:把小寫字元轉換為大寫字元
- swab:交換輸入的每對位元組
- noerror:出錯時不停止
- notrunc:不截短輸出檔案
- sync:將每個輸入塊填充到ibs個位元組,不足部分用空(NUL)字元補齊。
二、dd應用例項
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.將備份檔案恢復到指定盤
1 |
dd if = /root/image of= /dev/hdb
|
4.備份/dev/hdb全盤資料,並利用gzip工具進行壓縮,儲存到指定路徑
1 |
dd if = /dev/hdb | gzip > /root/image .gz
|
5.將壓縮的備份檔案恢復到指定盤
1 |
gzip - dc /root/image .gz | dd of= /dev/hdb
|
6.備份與恢復MBR
備份磁碟開始的512個位元組大小的MBR資訊到指定檔案:
1 |
dd if = /dev/hda of= /root/image count=1 bs=512
|
count=1指僅拷貝一個塊;bs=512指塊大小為512個位元組。
恢復:
1 |
dd if = /root/image of= /dev/had
|
將備份的MBR資訊寫到磁碟開始部分
7.備份軟盤
1 |
dd if = /dev/fd0 of=disk.img count=1 bs=1440k (即塊大小為1.44M)
|
8.拷貝記憶體內容到硬碟
1 |
dd if = /dev/mem of= /root/mem .bin bs=1024 (指定塊大小為1k)
|
9.拷貝光碟內容到指定資料夾,並儲存為cd.iso檔案
1 |
dd if = /dev/cdrom (hdc) of= /root/cd .iso
|
10.增加swap分割槽檔案大小
第一步:建立一個大小為256M的檔案:
1 |
dd if = /dev/zero of= /swapfile bs=1024 count=262144
|
第二步:把這個檔案變成swap檔案:
1 |
mkswap /swapfile
|
第三步:啟用這個swap檔案:
1 |
swapon /swapfile
|
第四步:編輯/etc/fstab檔案,使在每次開機時自動載入swap檔案:
1 |
/swapfile swap swap default 0 0
|
11.銷燬磁碟資料
1 |
dd if = /dev/urandom of= /dev/hda1
|
注意:利用隨機的資料填充硬碟,在某些必要的場合可以用來銷燬資料。
12.測試硬碟的讀寫速度
1 2 |
dd if = /dev/zero bs=1024 count=1000000 of= /root/1Gb . file
dd if = /root/1Gb . file bs=64k | dd of= /dev/null
|
通過以上兩個命令輸出的命令執行時間,可以計算出硬碟的讀、寫速度。
13.確定硬碟的最佳塊大小:
1 2 3 4 5 6 7 |
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
dd if = /dev/zero bs=8192 count=125000 of= /root/1Gb . file
|
通過比較以上命令輸出中所顯示的命令執行時間,即可確定系統最佳的塊大小。
14.修復硬碟:
1 |
dd if = /dev/sda of= /dev/sda 或 dd if = /dev/hda of= /dev/hda
|
當硬碟較長時間(一年以上)放置不使用後,磁碟上會產生magnetic flux point,當磁頭讀到這些區域時會遇到困難,並可能導致I/O錯誤。當這種情況影響到硬碟的第一個扇區時,可能導致硬碟報廢。上邊的命令有可能使這些數 據起死回生。並且這個過程是安全、高效的。
15.利用netcat遠端備份
1 |
dd if = /dev/hda bs=16065b | netcat < targethost-IP > 1234
|
在源主機上執行此命令備份/dev/hda
1 |
netcat -l -p 1234 | dd of= /dev/hdc bs=16065b
|
在目的主機上執行此命令來接收資料並寫入/dev/hdc
1 2 3 |
netcat -l -p 1234 | bzip2 > partition.img
netcat -l -p 1234 | gzip > partition.img
|
以上兩條指令是目的主機指令的變化分別採用bzip2、gzip對資料進行壓縮,並將備份檔案儲存在當前目錄。
16.將一個很大的視訊檔案中的第i個位元組的值改成0x41(也就是大寫字母A的ASCII值)
1 |
echo A | dd of=bigfile seek=$i bs=1 count=1 conv=notrunc
|
三、/dev/null和/dev/zero的區別
/dev/null,外號叫無底洞,你可以向它輸出任何資料,它通吃,並且不會撐著!
/dev/zero,是一個輸入裝置,你可你用它來初始化檔案。該裝置無窮盡地提供0,可以使用任何你需要的數目——裝置提供的要多的多。他可以用於向裝置或檔案寫入字串0。
/dev/null——它是空裝置,也稱為位桶(bit bucket)。任何寫入它的輸出都會被拋棄。如果不想讓訊息以標準輸出顯示或寫入檔案,那麼可以將訊息重定向到位桶。
1 2 3 4 5 |
heng@me: if = /dev/zero of=. /test .txt bs=1k count=1
heng@me: ls –l
total 4
-rw-r--r-- 1 oracle dba 1024 Jul 15 16:56 test .txt
heng@me: find / -name access_log 2> /dev/null
|
使用/dev/nul
把/dev/null看作”黑洞”, 它等價於一個只寫檔案,所有寫入它的內容都會永遠丟失.,而嘗試從它那兒讀取內容則什麼也讀不到。然而, /dev/null對命令列和指令碼都非常的有用
禁止標準輸出
1 |
heng@me: cat $filename > /dev/null #檔案內容丟失,而不會輸出到標準輸出.
|
禁止標準錯誤
1 |
heng@me: rm $badname 2> /dev/null #這樣錯誤資訊[標準錯誤]就被丟到太平洋去了
|
禁止標準輸出和標準錯誤的輸出
1 |
heng@me: cat $filename 2> /dev/null > /dev/null
|
如果”$filename”不存在,將不會有任何錯誤資訊提示;如果”$filename”存在, 檔案的內容不會列印到標準輸出。因此,上面的程式碼根本不會輸出任何資訊。當只想測試命令的退出碼而不想有任何輸出時非常有用。
使用/dev/zero
像/dev/null一樣, /dev/zero也是一個偽檔案, 但它實際上產生連續不斷的null的流(二進位制的零流,而不是ASCII型的)。 寫入它的輸出會丟失不見, 而從/dev/zero讀出一連串的null也比較困難, 雖然這也能通過od或一個十六進位制編輯器來做到。
/dev/zero主要的用處是用來建立一個指定長度用於初始化的空檔案,就像臨時交換檔案。
用/dev/zero建立一個交換臨時檔案
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 |
#!/bin/bash
# 建立一個交換檔案.
ROOT_UID=0 # Root 使用者的 $UID 是 0.
E_WRONG_USER=65 # 不是 root?
FILE= /swap
BLOCKSIZE=1024
MINBLOCKS=40
SUCCESS=0
# 這個指令碼必須用root來執行.
if [ "$UID" - ne "$ROOT_UID" ]
then
echo ; echo "You must be root to run this script." ; echo
exit $E_WRONG_USER
fi
blocks=${1:-$MINBLOCKS} # 如果命令列沒有指定,
#+ 則設定為預設的40塊.
# 上面這句等同如:
# --------------------------------------------------
# if [ -n "$1" ]
# then
# blocks=$1
# else
# blocks=$MINBLOCKS
# fi
# --------------------------------------------------
if [ "$blocks" -lt $MINBLOCKS ]
then
blocks=$MINBLOCKS # 最少要有 40 個塊長.
fi
echo "Creating swap file of size $blocks blocks (KB)."
dd if = /dev/zero of=$FILE bs=$BLOCKSIZE count=$blocks # 把零寫入檔案.
mkswap $FILE $blocks # 將此檔案建為交換檔案(或稱交換分割槽).
swapon $FILE # 啟用交換檔案.
echo "Swap file created and activated."
exit $SUCCESS
|
關於 /dev/zero 的另一個應用是為特定的目的而用零去填充一個指定大小的檔案, 如掛載一個檔案系統到環回裝置 (loopback device)或"安全地" 刪除一個檔案。
例子建立ramdisk
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 |
#!/bin/bash
# ramdisk.sh
# "ramdisk"是系統RAM記憶體的一段,
#+ 它可以被當成是一個檔案系統來操作.
# 它的優點是存取速度非常快 (包括讀和寫).
# 缺點: 易失性, 當計算機重啟或關機時會丟失資料.
#+ 會減少系統可用的RAM.
# 10 # 那麼ramdisk有什麼作用呢?
# 儲存一個較大的資料集在ramdisk, 比如一張表或字典,
#+ 這樣可以加速資料查詢, 因為在記憶體裡查詢比在磁盤裡查詢快得多.
E_NON_ROOT_USER=70 # 必須用root來執行.
ROOTUSER_NAME=root
MOUNTPT= /mnt/ramdisk
SIZE=2000 # 2K 個塊 (可以合適的做修改)
BLOCKSIZE=1024 # 每塊有1K (1024 byte) 的大小
DEVICE= /dev/ram0 # 第一個 ram 裝置
username=` id -nu`
if [ "$username" != "$ROOTUSER_NAME" ]
then
echo "Must be root to run " ` basename $0` "."
exit $E_NON_ROOT_USER
fi
if [ ! -d "$MOUNTPT" ] # 測試掛載點是否已經存在了,
then #+ 如果這個指令碼已經運行了好幾次了就不會再建這個目錄了
mkdir $MOUNTPT #+ 因為前面已經建立了.
fi
dd if = /dev/zero of=$DEVICE count=$SIZE bs=$BLOCKSIZE
# 把RAM裝置的內容用零填充.
# 為何需要這麼做?
mke2fs $DEVICE # 在RAM裝置上建立一個ext2檔案系統.
mount $DEVICE $MOUNTPT # 掛載裝置.
chmod 777 $MOUNTPT # 使普通使用者也可以存取這個ramdisk.
# 但是, 只能由root來缷載它.
echo "" $MOUNTPT " now available for use."
# 現在 ramdisk 即使普通使用者也可以用來存取檔案了.
# 注意, ramdisk是易失的, 所以當計算機系統重啟或關機時ramdisk裡的內容會消失.
# 拷貝所有你想儲存檔案到一個常規的磁碟目錄下.
# 重啟之後, 執行這個指令碼再次建立起一個 ramdisk.
# 僅重新載入 /mnt/ramdisk 而沒有其他的步驟將不會正確工作.
# 如果加以改進, 這個指令碼可以放在 /etc/rc.d/rc.local,
#+ 以使系統啟動時能自動設立一個ramdisk.
# 這樣很合適速度要求高的資料庫伺服器.
exit 0
|