Linux的dd命令使用詳解
阿新 • • 發佈:2018-11-05
http://blog.sina.com.cn/s/blog_8b5bb24f01016y3o.html
一、dd命令的解釋
dd:用指定大小的塊拷貝一個檔案,並在拷貝的同時進行指定的轉換。 注意:指定數字的地方若以下列字元結尾,則乘以相應的數字:b=512;c=1;k=1024;w=2 引數註釋: 1. if=檔名:輸入檔名,預設為標準輸入。即指定原始檔。< if=input file > 2. of=檔名:輸出檔名,預設為標準輸出。即指定目的檔案。< of=output file > 3. ibs=bytes:一次讀入bytes個位元組,即指定一個塊大小為bytes個位元組。 obs=bytes:一次輸出bytes個位元組,即指定一個塊大小為bytes個位元組。 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)字元補齊。 二、dd應用例項#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”存在, 檔案的內容不會列印到標準輸出。 因此,上面的程式碼根本不會輸出任何資訊。當只想測試命令的退出碼而不想有任何輸出時非常有用。 #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 [ “ ROOT_UID” ] then echo; echo “You must be root to run this script.”; echo exit $E_WRONG_USER fi blocks= MINBLOCKS} # 如果命令列沒有指定, #+ 則設定為預設的40塊. # 上面這句等同如: # ————————————————– # if [ -n “$1” ] # then # blocks=$1 # else # blocks=$MINBLOCKS # fi # ————————————————– if [ “ MINBLOCKS ] then blocks=$MINBLOCKS # 最少要有 40 個塊長. fi echo “Creating swap file of size $blocks blocks (KB).” dd if=/dev/zero of= BLOCKSIZE count=$blocks # 把零寫入檔案. mkswap 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 [ “ 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= SIZE bs=$BLOCKSIZE # 把RAM裝置的內容用零填充. # 為何需要這麼做? mke2fs $DEVICE # 在RAM裝置上建立一個ext2檔案系統. mount 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
轉自maxiongying的部落格:https://www.cnblogs.com/senior-engineer/p/6211247.html