學習於:http://blog.sina.com.cn/s/blog_8b5bb24f01016y3o.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)字符補齊。busybox dd if=/dev/zero of=/dev/block/mmcblk0 bs=512 seek=1 count=1 conv=sync
解釋:
f=/dev/zero:輸入文件名爲/dev/zero
of=/dev/mmcblk0:輸出文件名爲/dev/mmcblk0
bs=512:讀塊和寫塊的大小都爲512B(這裏的輸出文件爲一個塊設備,塊大小的設置跟塊設備中每塊的大小相關)
seek=1:跳過第一個塊
count:只拷貝一個塊
conv:若讀取的輸入塊不足512B,那麼不足的部分填充NUL
sudo dd iflag=dsync oflag=dsync if=sd.bin of=/dev/sdb seek=1
解析:
iflag=dsync:表示輸入文件讀取時不經過緩衝區,一塊一塊地讀取(塊的大小爲緩衝區大小),直到讀取完成。
oflag=dsync:表示輸出文件不經過緩衝區,來一塊,寫入一塊。
if=210.bin:表示輸入文件爲210.bin
of=/dev/sdb:表示輸出文件爲sd卡
seek=1:表示跳過第0塊,從第1塊開始寫入
oflag=dsync、conv=sync的區別就相當於用不用緩衝區FIFO的區別一樣,如果不想用緩衝區就一定要使用oflag指定參數。
詳情介紹點此跳轉:http://blog.csdn.net/menogen/article/details/38059671
二、dd應用實例 1.將本地的/dev/hdb整盤備份到/dev/hdd #dd if=/dev/hdb of=/dev/hdd 2.將/dev/hdb全盤數據備份到指定路徑的image文件 #dd if=/dev/hdb of=/root/image 3.將備份文件恢復到指定盤 #dd if=/root/image of=/dev/hdb 4.備份/dev/hdb全盤數據,並利用gzip工具進行壓縮,保存到指定路徑 #dd if=/dev/hdb |
gzip > /root/image.gz 5.將壓縮的備份文件恢復到指定盤 #gzip -dc /root/image.gz |
dd of=/dev/hdb 6.備份與恢復MBR 備份磁盤開始的512個字節大小的MBR信息到指定文件: #dd if=/dev/hda of=/root/image count=1 bs=512 count=1指僅拷貝一個塊;bs=512指塊大小爲512個字節。 恢復: #dd if=/root/image of=/dev/had 將備份的MBR信息寫到磁盤開始部分 7.備份軟盤 #dd if=/dev/fd0 of=disk.img count=1 bs=1440k (即塊大小爲1.44M) 8.拷貝內存內容到硬盤 #dd if=/dev/mem of=/root/mem.bin bs=1024 (指定塊大小爲1k) 9.拷貝光盤內容到指定文件夾,並保存爲cd.iso文件 #dd if=/dev/cdrom(hdc) of=/root/cd.iso 10.增加swap分區文件大小 第一步:創建一個大小爲256M的文件: #dd if=/dev/zero of=/swapfile bs=1024 count=262144 第二步:把這個文件變成swap文件: #mkswap /swapfile 第三步:啓用這個swap文件: #swapon /swapfile 第四步:編輯/etc/fstab文件,使在每次開機時自動加載swap文件: /swapfile swap swap default 0 0 11.銷燬磁盤數據 #dd if=/dev/urandom of=/dev/hda1 注意:利用隨機的數據填充硬盤,在某些必要的場合可以用來銷燬數據。 12.測試硬盤的讀寫速度 #dd if=/dev/zero bs=1024 count=1000000 of=/root/1Gb.file #dd if=/root/1Gb.file bs=64k |
dd of=/dev/null 通過以上兩個命令輸出的命令執行時間,可以計算出硬盤的讀、寫速度。 13.確定硬盤的最佳塊大小: #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.修復硬盤: #dd if=/dev/sda of=/dev/sda 或dd if=/dev/hda of=/dev/hda 當硬盤較長時間(一年以上)放置不使用後,磁盤上會產生magnetic flux point,當磁頭讀到這些區域時會遇到困難,並可能導致I/O錯誤。當這種情況影響到硬盤的第一個扇區時,可能導致硬盤報廢。上邊的命令有可能使這些數 據起死回生。並且這個過程是安全、高效的。 15.利用netcat遠程備份 #dd if=/dev/hda bs=16065b |
netcat < targethost-IP > 1234 在源主機上執行此命令備份/dev/hda #netcat -l -p 1234 |
dd of=/dev/hdc bs=16065b 在目的主機上執行此命令來接收數據並寫入/dev/hdc #netcat -l -p 1234 |
bzip2 > partition.img #netcat -l -p 1234 |
gzip > partition.img 以上兩條指令是目的主機指令的變化分別採用bzip2、gzip對數據進行壓縮,並將備份文件保存在當前目錄。 將一個很大的視頻文件中的第i個字節的值改成0x41(也就是大寫字母A的ASCII值) 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)。任何寫入它的輸出都會被拋棄。如果不想讓消息以標準輸出顯示或寫入文件,那麼可以將消息重定向到位桶。 #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 禁止標準輸出 #cat $filename >/dev/null 文件內容丟失,而不會輸出到標準輸出. l 禁止標準錯誤 #rm $badname 2>/dev/null 這樣錯誤信息[標準錯誤]就被丟到太平洋去了 l 禁止標準輸出和標準錯誤的輸出 #cat $filename 2>/dev/null >/dev/null 如果"$filename"不存在,將不會有任何錯誤信息提示;如果"$filename"存在, 文件的內容不會打印到標準輸出。 因此,上面的代碼根本不會輸出任何信息。當只想測試命令的退出碼而不想有任何輸出時非常有用。 #cat $filename &>/dev/null 這樣其實也可以, 由 Baris Cicek 指出 自動清空日誌文件的內容 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 有同樣的效果, 但不會產生新的進程.(因爲:是內建的) #cat /dev/null > /var/log/wtmp 隱藏cookie而不再使用 特別適合處理這些由商業Web站點發送的討厭的"cookies" #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創建一個交換臨時文件 #!/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 #!/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 |
---|
作者:種瓜大爺
來源:CSDN
原文:https://blog.csdn.net/czg13548930186/article/details/78608034
版權聲明:本文爲博主原創文章,轉載請附上博文鏈接!