Linux系統備份還原工具1(DD)


注意:只要時運行備份,建議都使用Ubuntu的Live CD功能啟動來操作(即啟動盤下的試用Ubuntu而不安裝的功能),因為這樣可以減少資源占用造成的備份不完整。

說明:

1、使用DD進行硬盤備份可以實現類似Ghost的基本功能,比如整個硬盤備份(包括MBR),單分區備份,單備份MBR,硬盤對拷。

2、如果分區對分區進行拷貝時,當兩個分區大小不一致的情況,在恢復完之后需要重新調整新分區大小。兩個硬盤對拷的情況也需要這樣去調整。

3、使用DD備份分區或整塊硬盤時,如果分區是100G的容量,而只使用了20G的容量,那么備份后輸出的文件大小是100G;這種情況可以使用壓縮解決,不過不一定有效,結果可能還是一樣很大。

4、DD不能解決文件排序,磁盤碎片整理等問題,所以在備份后文件的大小問題很難解決。

5、DD一般使用在本機的硬盤備份和還原上,也就是針對原分區的操作。或者硬盤對拷。因為這樣完成后不需要修改任何東西。

6、如果使用DD把系統還原到另一個新硬件上,估計要修改很多東西,待實踐。

7、DD還可以用做測試硬盤速度。

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

使用實例:

說明:在Linux上,一塊硬盤或者一個分區都由一個目錄表示,一般存在於系統根目錄的/dev/之下。例如/dev/hda代表你的第一塊IDE硬盤,/dev/sdb代表第二塊SCSI硬盤,/dev/fd0代表系統的軟盤驅動器等等。同樣每塊硬盤上的分區也有獨特的目錄名,例如/dev/hda1表示你第一塊硬盤上的第一個分區。

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對數據進行壓縮,並將備份文件保存在當前目錄。

16、將一個很大的視頻文件中的第i個字節的值改成0x41(也就是大寫字母A的ASCII值)

echo A | dd of=bigfile seek=$i bs=1 count=1 conv=notrunc

 17、備份分區

dd if=/dev/sda1 of=~/partition1.img 

18、光盤備份

dd if=/dev/cdrom of=tgsservice.iso bs=2048

注意:如果光盤是自動掛載的,在使用dd命令創建iso映像之前最好umount掉以避免造成對CD ROM不必要的訪問。

19、在上面的拷貝過程中,並不知道拷貝了多少,只有最終結束時才顯示出時間、拷貝速度。為了查看進度,可以在另一個終端輸入:

sudo watch -n 5 killall -USR1 dd

20、還原分區表,跳過主引導記錄

dd if=/backup/mbr.img of=/dev/sda bs=1 count=64 skip=446 seek=446

使用技巧:

1、修復還原到大小不一樣的分區時的設置:

sudo dd if=/dev/sda1 of=/dev/sdb1
sudo e2fsck -f /dev/sdb1
sudo resize2fs /dev/sdb1

2、硬盤和硬盤對拷時不需要上述設置。

3、在dd生成鏡像之前,先umount所有if和of設備的分區。這樣可以確保在dd的過程中文件系統沒有被改變。

4、如果把鏡像恢復到另一台計算機上,可能會發現網卡是eth1,而不是eth0。這是因為/etc/udev/rules.d/70-persistent-net.rules文件把做鏡像的計算機的網卡作為eth0登記了。  如果網絡腳本對eth0進行了處理,而沒有對eth1進行處理,那么不修改網絡腳本,可能就無法上網。也許會希望在做鏡像之前,先刪除/etc/udev/rules.d/70-persistent-net.rules文件。這樣恢復鏡像時,網卡的名字就是eth0。   就不會造成在恢復后的計算機上無法上網的問題。

5、如果硬件不一樣的機器,可以嘗試以下方法:

sudo chroot
#更新grub
sudo update-grub
#更新fstab的UUID
/etc/fstab

 

參考:

http://blog.csdn.net/linux_hua130/article/details/51346176

http://www.4wei.cn/archives/1002013

http://www.linuxde.net/2013/03/12928.html

http://tieba.baidu.com/p/2840814432

http://blog.csdn.net/shendl/article/details/7384755

http://blog.csdn.net/shendl/article/details/7960219(把物理機轉成虛擬機鏡像)

http://wiki.ubuntu.org.cn/Ubuntu%E5%A4%87%E4%BB%BD%E4%B8%8E%E8%BF%98%E5%8E%9F#.E5.A4.87.E4.BB.BDmbr

http://forum.ubuntu.org.cn/viewtopic.php?t=469838


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM