本文轉自:http://www.javashuo.com/article/p-qadeghtv-by.htmlhtml
1、dd命令的解釋linux
dd:用指定大小的塊拷貝一個文件,並在拷貝的同時進行指定的轉換。數據庫
注意:指定數字的地方若如下列字符結尾,則乘以相應的數字:b=512;c=1;k=1024;w=2安全
參數註釋:bash
1. if=文件名:輸入文件名,缺省爲標準輸入。即指定源文件。< if=input file >服務器
2. of=文件名:輸出文件名,缺省爲標準輸出。即指定目的文件。< of=output file >cookie
3. ibs=bytes:一次讀入bytes個字節,即指定一個塊大小爲bytes個字節。oracle
obs=bytes:一次輸出bytes個字節,即指定一個塊大小爲bytes個字節。dom
bs=bytes:同時設置讀入/輸出的塊大小爲bytes個字節。編輯器
4. cbs=bytes:一次轉換bytes個字節,即指定轉換緩衝區大小。
5. skip=blocks:從輸入文件開頭跳過blocks個塊後再開始複製。
6. seek=blocks:從輸出文件開頭跳過blocks個塊後再開始複製。
注意:一般只用當輸出文件是磁盤或磁帶時纔有效,即備份到磁盤或磁帶時纔有效。
7. count=blocks:僅拷貝blocks個塊,塊大小等於ibs指定的字節數。
8. conv=conversion:用指定的參數轉換文件。
ascii:轉換ebcdic爲ascii
ebcdic:轉換ascii爲ebcdic
ibm:轉換ascii爲alternate ebcdic
block:把每一行轉換爲長度爲cbs,不足部分用空格填充
unblock:使每一行的長度都爲cbs,不足部分用空格填充
lcase:把大寫字符轉換爲小寫字符
ucase:把小寫字符轉換爲大寫字符
swab:交換輸入的每對字節
noerror:出錯時不中止
notrunc:不截短輸出文件
sync:將每一個輸入塊填充到ibs個字節,不足部分用空(NUL)字符補齊。
2、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
|
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
|
netcat -l -p 1234 |
bzip2
> partition.img
netcat -l -p 1234 |
gzip
> partition.img
|
以上兩條指令是目的主機指令的變化分別採用bzip二、gzip對數據進行壓縮,並將備份文件保存在當前目錄。
將一個很大的視頻文件中的第i個字節的值改爲0x41(也就是大寫字母A的ASCII值)
1
|
echo
A |
dd
of=bigfile seek=$i bs=1 count=1 conv=notrunc
|
3、/dev/null和/dev/zero的區別
/dev/null,外號叫無底洞,你能夠向它輸出任何數據,它通吃,而且不會撐着!
/dev/zero,是一個輸入設備,你可你用它來初始化文件。該設備無窮盡地提供0,可使用任何你須要的數目——設備提供的要多的多。他能夠用於向設備或文件寫入字符串0。
/dev/null------它是空設備,也稱爲位桶(bit bucket)。任何寫入它的輸出都會被拋棄。若是不想讓消息以標準輸出顯示或寫入文件,那麼能夠將消息重定向到位桶。
1
2
3
4
5
|
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
find
/ -name access_log 2>
/dev/null
|
3.1使用/dev/null
把/dev/null看做"黑洞", 它等價於一個只寫文件,全部寫入它的內容都會永遠丟失.,而嘗試從它那兒讀取內容則什麼也讀不到。然而, /dev/null對命令行和腳本都很是的有用
l 禁止標準輸出
1
|
cat
$filename >
/dev/null
|
文件內容丟失,而不會輸出到標準輸出.
l 禁止標準錯誤
1
|
rm
$badname 2>
/dev/null
|
這樣錯誤信息[標準錯誤]就被丟到太平洋去了
l 禁止標準輸出和標準錯誤的輸出
1
|
cat
$filename 2>
/dev/null
>
/dev/null
|
若是"$filename"不存在,將不會有任何錯誤信息提示;若是"$filename"存在,文件的內容不會打印到標準輸出。
所以,上面的代碼根本不會輸出任何信息。當只想測試命令的退出碼而不想有任何輸出時很是有用。
1
|
cat
$filename &>
/dev/null
|
這樣其實也能夠, 由 Baris Cicek 指出
自動清空日誌文件的內容
1
2
|
l Deleting contents of a
file
, but preserving the
file
itself, with all attendant permissions(from Example 2-1 and Example 2-3):
cat
/dev/null
>
/var/log/messages
|
# : > /var/log/messages 有一樣的效果,但不會產生新的進程.(由於:是內建的)
1
|
cat
/dev/null
>
/var/log/wtmp
|
隱藏cookie而再也不使用
特別適合處理這些由商業Web站點發送的討厭的"cookies"
1
2
3
4
5
|
if
[ -f ~/.netscape
/cookies
]
# 若是存在則刪除.
then
rm
-f ~/.netscape
/cookies
fi
ln
-s
/dev/null
~/.netscape
/cookies
|
如今全部的cookies都會丟入黑洞而不會保存在磁盤上了.
3.2使用/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
|
#!/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
|