天天看點

執行個體解dd指令用法

一、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.備份磁盤開始的512個位元組大小的MBR資訊到指定檔案

   dd if=/dev/hda of=/root/image count=1 bs=512

   count=1指僅拷貝一個塊;bs=512指塊大小為512個位元組。

   恢複:dd if=/root/image of=/dev/hda

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光牒内容到指定檔案夾,并儲存為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錯誤。當這種情況影響到硬碟的第一個扇區時,可能導緻硬碟報廢。上邊的指令有可能使這些資料起死回生。并且這個過程是安全、高效的。

/dev/null和/dev/zero的差別

/dev/null,外号叫無底洞,你可以向它輸出任何資料,它通吃,并且不會撐着!

/dev/zero,是一個輸入裝置,你可你用它來初始化檔案。

/dev/null,外号叫無底洞,你可以向它輸出任何資料,它通吃,并且不會撐着!

/dev/zero,是一個輸入裝置,你可你用它來初始化檔案。

/dev/null------它是空裝置,也稱為位桶(bit bucket)。任何寫入它的輸出都會被抛棄。如果不想讓消息以标準輸出顯示或寫入檔案,那麼可以将消息重定向到位桶。

/dev/zero------該裝置無窮盡地提供0,可以使用任何你需要的數目——裝置提供的要多的多。他可以用于向裝置或檔案寫入字元串0。

o[email protected] oracle]$if=/dev/zero of=./test.txt bs=1k count=1

[email protected] oracle]$ ls -l

total 4

-rw-r--r--    1 oracle   dba          1024 Jul 15 16:56 test.txt

eg,

    find / -name access_log  2>/dev/null

使用/dev/null 

把/dev/null看作"黑洞". 它非常等價于一個隻寫檔案. 所有寫入它的内容都會永遠丢失. 而嘗試從它那兒讀取内容則什麼也讀不到. 然而, /dev/null對指令行和腳本都非常的有用.

禁止标準輸出.    1 cat $filename >/dev/null

   2 # 檔案内容丢失,而不會輸出到标準輸出.

禁止标準錯誤 (來自例子 12-3).    1 rm $badname 2>/dev/null

   2 #           這樣錯誤資訊[标準錯誤]就被丢到太平洋去了.

禁止标準輸出和标準錯誤的輸出.    1 cat $filename 2>/dev/null >/dev/null

   2 # 如果"$filename"不存在,将不會有任何錯誤資訊提示.

   3 # 如果"$filename"存在, 檔案的内容不會列印到标準輸出.

   4 # 是以Therefore, 上面的代碼根本不會輸出任何資訊.

   5 #

   6 #  當隻想測試指令的退出碼而不想有任何輸出時非常有用。

   7 #

   8 #

   9 # cat $filename &>/dev/null

  10 #     也可以, 由 Baris Cicek 指出.

Deleting contents of a file, but preserving the file itself, with all attendant permissions (from Example 2-1 and Example 2-3):    1 cat /dev/null > /var/log/messages

   2 #  : > /var/log/messages   有同樣的效果, 但不會産生新的程序.(因為:是内建的)

   3 

   4 cat /dev/null > /var/log/wtmp

自動清空日志檔案的内容 (特别适合處理這些由商業Web站點發送的讨厭的"cookies"):

--------------------------------------------------------------------------------

例子 28-1. 隐藏cookie而不再使用

   1 if [ -f ~/.netscape/cookies ]  # 如果存在則删除.

   2 then

   3   rm -f ~/.netscape/cookies

   4 fi

   5 

   6 ln -s /dev/null ~/.netscape/cookies

   7 # 現在所有的cookies都會丢入黑洞而不會儲存在磁盤上了.

--------------------------------------------------------------------------------

使用/dev/zero 

像/dev/null一樣, /dev/zero也是一個僞檔案, 但它實際上産生連續不斷的null的流(二進制的零流,而不是ASCII型的). 寫入它的輸出會丢失不見, 而從/dev/zero讀出一連串的null也比較困難, 雖然這也能通過od或一個十六進制編輯器來做到. /dev/zero主要的用處是用來建立一個指定長度用于初始化的空檔案,就像臨時交換檔案.

--------------------------------------------------------------------------------

例子 28-2. 用/dev/zero建立一個交換臨時檔案

   1 #!/bin/bash

   2 # 建立一個交換檔案.

   3 

   4 ROOT_UID=0         # Root 使用者的 $UID 是 0.

   5 E_WRONG_USER=65    # 不是 root?

   6 

   7 FILE=/swap

   8 BLOCKSIZE=1024

   9 MINBLOCKS=40

  10 SUCCESS=0

  11 

  12 

  13 # 這個腳本必須用root來運作.

  14 if [ "$UID" -ne "$ROOT_UID" ]

  15 then

  16   echo; echo "You must be root to run this script."; echo

  17   exit $E_WRONG_USER

  18 fi  

  19   

  20 

  21 blocks=${1:-$MINBLOCKS}          #  如果指令行沒有指定,

  22                                  #+ 則設定為預設的40塊.

  23 # 上面這句等同如:

  24 # --------------------------------------------------

  25 # if [ -n "$1" ]

  26 # then

  27 #   blocks=$1

  28 # else

  29 #   blocks=$MINBLOCKS

  30 # fi

  31 # --------------------------------------------------

  32 

  33 

  34 if [ "$blocks" -lt $MINBLOCKS ]

  35 then

  36   blocks=$MINBLOCKS              # 最少要有 40 個塊長.

  37 fi  

  38 

  39 

  40 echo "Creating swap file of size $blocks blocks (KB)."

  41 dd if=/dev/zero of=$FILE bs=$BLOCKSIZE count=$blocks  # 把零寫入檔案.

  42 

  43 mkswap $FILE $blocks             # 将此檔案建為交換檔案(或稱交換分區).

  44 swapon $FILE                     # 激活交換檔案.

  45 

  46 echo "Swap file created and activated."

  47 

  48 exit $SUCCESS

--------------------------------------------------------------------------------

關于 /dev/zero 的另一個應用是為特定的目的而用零去填充一個指定大小的檔案, 如挂載一個檔案系統到環回裝置 (loopback device) (參考例子 13-8) 或"安全地" 删除一個檔案(參考例子 12-55).

--------------------------------------------------------------------------------

例子 28-3. 建立ramdisk

   1 #!/bin/bash

   2 # ramdisk.sh

   3 

   4 #  "ramdisk"是系統RAM記憶體的一段,

   5 #+ 它可以被當成是一個檔案系統來操作.

   6 #  它的優點是存取速度非常快 (包括讀和寫).

   7 #  缺點: 易失性, 當計算機重新開機或關機時會丢失資料.

   8 #+       會減少系統可用的RAM.

   9 #

  10 #  那麼ramdisk有什麼作用呢?

  11 #  儲存一個較大的資料集在ramdisk, 比如一張表或字典,

  12 #+ 這樣可以加速資料查詢, 因為在記憶體裡查找比在磁盤裡查找快得多.

  13 

  14 

  15 E_NON_ROOT_USER=70             # 必須用root來運作.

  16 ROOTUSER_NAME=root

  17 

  18 MOUNTPT=/mnt/ramdisk

  19 SIZE=2000                      # 2K 個塊 (可以合适的做修改)

  20 BLOCKSIZE=1024                 # 每塊有1K (1024 byte) 的大小

  21 DEVICE=/dev/ram0               # 第一個 ram 裝置

  22 

  23 username=`id -nu`

  24 if [ "$username" != "$ROOTUSER_NAME" ]

  25 then

  26   echo "Must be root to run /"`basename $0`/"."

  27   exit $E_NON_ROOT_USER

  28 fi

  29 

  30 if [ ! -d "$MOUNTPT" ]         #  測試挂載點是否已經存在了,

  31 then                           #+ 如果這個腳本已經運作了好幾次了就不會再建這個目錄了

  32   mkdir $MOUNTPT               #+ 因為前面已經建立了.

  33 fi

  34 

  35 dd if=/dev/zero of=$DEVICE count=$SIZE bs=$BLOCKSIZE  # 把RAM裝置的内容用零填充.

  36                                                       # 為何需要這麼做?

  37 mke2fs $DEVICE                 # 在RAM裝置上建立一個ext2檔案系統.

  38 mount $DEVICE $MOUNTPT         # 挂載裝置.

  39 chmod 777 $MOUNTPT             # 使普通使用者也可以存取這個ramdisk.

  40                                # 但是, 隻能由root來缷載它.

  41 

  42 echo "/"$MOUNTPT/" now available for use."

  43 # 現在 ramdisk 即使普通使用者也可以用來存取檔案了.

  44 

  45 #  注意, ramdisk是易失的, 是以當計算機系統重新開機或關機時ramdisk裡的内容會消失.

  46 #

  47 #  拷貝所有你想儲存檔案到一個正常的磁盤目錄下.

  48 

  49 # 重新開機之後, 運作這個腳本再次建立起一個 ramdisk.

  50 # 僅重新加載 /mnt/ramdisk 而沒有其他的步驟将不會正确工作.

  51 

  52 #  如果加以改進, 這個腳本可以放在 /etc/rc.d/rc.local,

  53 #+ 以使系統啟動時能自動設立一個ramdisk.

  54 #  這樣很合适速度要求高的資料庫伺服器.

  55 

  56 exit 0

這樣,一些諸如一些錯誤資訊就不會顯示出來。

二、參數:

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)字元補齊。

繼續閱讀