「ディスクのクローン」の版間の差分

提供: ArchWiki
ナビゲーションに移動 検索に移動
10行目: 10行目:
 
== dd を使う ==
 
== dd を使う ==
   
  +
dd コマンドはシンプルでありながら、多目的に使える強力なツールです。ファイルシステムのタイプやオペレーティングシステムとは関係なく、ブロックごとに、コピーを行うことができます。ライブ CD などの、ライブ環境から dd を使用すると便利です。
The dd command is a simple, yet versatile and powerful tool. It can be used to copy from source to destination, block-by-block, regardless of their filesystem types or operating systems. A convenient method is to use dd from a live environment, as in a livecd.
 
   
 
{{Warning|
 
{{Warning|
19行目: 19行目:
 
=== パーティションのクローン ===
 
=== パーティションのクローン ===
   
  +
物理ディスク {{ic|/dev/sda}} のパーティション 1 を、物理ディスク {{ic|/dev/sdb}} のパーティション 1 に複製。
From physical disk /dev/sda, partition 1, to physical disk /dev/sdb, partition 1.
 
 
# dd if=/dev/sda1 of=/dev/sdb1 bs=512 conv=noerror,sync
 
# dd if=/dev/sda1 of=/dev/sdb1 bs=512 conv=noerror,sync
   
{{Warning|If output file {{ic|1=of=}} (sdb1 in the example) does not exist, dd will create a file with this name and will start filling up your root file system.}}
+
{{Warning|If output file {{ic|1=of=}} ({{ic|sdb1}} in the example) does not exist, dd will create a file with this name and will start filling up your root file system.}}
   
 
=== ハードディスク全体のクローン ===
 
=== ハードディスク全体のクローン ===
   
  +
物理ディスク {{ic|/dev/sd''X''}} を物理ディスク {{ic|/dev/sdY}} に複製:
From physical disk /dev/sda to physical disk /dev/sdb
 
# dd if=/dev/sda of=/dev/sdb bs=512 conv=noerror,sync
+
# dd if=/dev/sd''X'' of=/dev/sd''Y'' bs=512 conv=noerror,sync
   
  +
このコマンドは MBR (とブートローダー)、全てのパーティション、UUID、データを含めディスクの全てを複製します。
This will clone the entire drive, including MBR (and therefore bootloader), all partitions, UUIDs, and data.
 
  +
* {{ic|noerror}} は読み取りエラーを全て無視して操作を続行します。dd のデフォルトの挙動ではエラーがあると dd は動作を停止します。
* {{ic|noerror}} instructs dd to continue operation, ignoring all read errors. Default behavior for dd is to halt at any error.
 
  +
* {{ic|sync}} は読み取りエラーが存在した場合、入力ブロックをゼロで埋めるため、データのオフセットも同期します。
* {{ic|sync}} fills input blocks with zeroes if there were any read errors, so data offsets stay in sync.
 
 
* {{ic|1=bs=512}} sets the block size to 512 bytes, the "classic" block size for hard drives. If and only if your hard drives have a 4K block size, you may use "4096" instead of "512". Also, please read the warning below, because there is more to this than just "block sizes" - it also influences how read errors propagate.
 
* {{ic|1=bs=512}} sets the block size to 512 bytes, the "classic" block size for hard drives. If and only if your hard drives have a 4K block size, you may use "4096" instead of "512". Also, please read the warning below, because there is more to this than just "block sizes" - it also influences how read errors propagate.
   
38行目: 38行目:
 
The dd utility technically has an "input block size" (IBS) and an "output block size" (OBS). When you set {{ic|bs}}, you effectively set both IBS and OBS. Normally, if your block size is, say, 1M, dd will read 1M bytes and write 1M bytes. But if a read error occurs, things will go wrong. Many people seem to think that dd will "fill up read errors with zeroes" if you use the {{ic|noerror,sync}} options, but this is not what happens. dd will, according to documentation, fill up the OBS to IBS size, which means adding zeroes at the end of the block. This means, for a disk, that effectively the whole 1M would become messed up because of a single 512 byte read error in the beginning of the read: ERROR6789 would become 678900000 instead of 000006789.
 
The dd utility technically has an "input block size" (IBS) and an "output block size" (OBS). When you set {{ic|bs}}, you effectively set both IBS and OBS. Normally, if your block size is, say, 1M, dd will read 1M bytes and write 1M bytes. But if a read error occurs, things will go wrong. Many people seem to think that dd will "fill up read errors with zeroes" if you use the {{ic|noerror,sync}} options, but this is not what happens. dd will, according to documentation, fill up the OBS to IBS size, which means adding zeroes at the end of the block. This means, for a disk, that effectively the whole 1M would become messed up because of a single 512 byte read error in the beginning of the read: ERROR6789 would become 678900000 instead of 000006789.
   
If you are positive that your disk does not contain any errors, you could proceed using a larger block size, which will increase the speed of your copying manyfold. For example, changing bs from 512 to 64K changed copying speed from 35MB/s to 120MB/s on a simple Celeron 2.7GHz system. But keep in mind, that read errors on the source disk will end up as ''block errors'' on the destination disk, i.e. a single 512 bytes read error will mess up the whole 64k output block.
+
If you are positive that your disk does not contain any errors, you could proceed using a larger block size, which will increase the speed of your copying manifold. For example, changing bs from 512 to 64K changed copying speed from 35MB/s to 120MB/s on a simple Celeron 2.7GHz system. But keep in mind, that read errors on the source disk will end up as ''block errors'' on the destination disk, i.e. a single 512 bytes read error will mess up the whole 64k output block.
   
 
{{Tip|If you would like to view dd progressing, you can send it a {{ic|USR1}} signal. {{ic|pidof dd}} will tell you the PID of dd, then use {{ic|kill -USR1}}. In one line: {{ic|kill -USR1 $(pidof dd)}}.}}
 
{{Tip|If you would like to view dd progressing, you can send it a {{ic|USR1}} signal. {{ic|pidof dd}} will tell you the PID of dd, then use {{ic|kill -USR1}}. In one line: {{ic|kill -USR1 $(pidof dd)}}.}}
   
 
{{Note|
 
{{Note|
* To regain unique UUIDs, use "tune2fs /dev/sdbX -U random" on every partitions. (works for ext* file systems only)
+
* To regain unique UUIDs of an Ext2/3/4 filesystem, use {{ic|tune2fs /dev/sd''XY'' -U random}} on every partitions.
 
* Partition table changes from dd are not registered by the kernel. To notify of changes without rebooting, use a utility like partprobe (part of GNU parted).
 
* Partition table changes from dd are not registered by the kernel. To notify of changes without rebooting, use a utility like partprobe (part of GNU parted).
 
}}
 
}}
49行目: 49行目:
 
=== MBR のバックアップ ===
 
=== MBR のバックアップ ===
   
  +
MBR はディスクの頭512バイトに保存されています。MBR は3つの構成部位から成ります:
The MBR is stored in the the first 512 bytes of the disk. It consist of 3 parts:
 
   
  +
# 最初の446バイトにはブートローダーが含まれます。
# The first 446 bytes contain the boot loader.
 
  +
# 次の64バイトにはパーティションテーブルが含まれます (16バイトごとに4エントリ、1つのエントリに1つのプライマリパーティション)。
# The next 64 bytes contain the partition table (4 entries of 16 bytes each, one entry for each primary partition).
 
  +
# 最後の2バイトには識別子が含まれます。
# The last 2 bytes contain an identifier
 
   
To save the MBR into the file "mbr.img":
+
MBR "mbr.img" ファイルに保存するには:
# dd if=/dev/hda of=/mnt/sda1/mbr.img bs=512 count=1
+
# dd if=/dev/sdX of=/path/to/mbr_file.img bs=512 count=1
   
To restore (be careful: this could destroy your existing partition table and with it access to all data on the disk):
+
リストアするには (be careful: this could destroy your existing partition table and with it access to all data on the disk):
# dd if=/mnt/sda1/mbr.img of=/dev/hda
+
# dd if=/path/to/mbr_file.img of=/dev/sdX
   
  +
ブートローダーだけをリストアして、プライマリパーティションテーブルのエントリはそのままにしたい場合、MBR の最初の446バイトだけをリストアしてください:
If you only want to restore the boot loader, but not the primary partition table entries, just restore the first 446 bytes of the MBR:
 
# dd if=/mnt/sda1/mbr.img of=/dev/hda bs=446 count=1
+
# dd if=/path/to/mbr_file.img of=/dev/sdX bs=446 count=1
   
  +
パーティションテーブルだけをリストアするには、次のコマンドを使用します:
To restore only the partition table, one must use
 
# dd if=/mnt/sda1/mbr.img of=/dev/hda bs=1 skip=446 count=64
+
# dd if=/path/to/mbr_file.img of=/dev/sdX bs=1 skip=446 count=64
   
  +
完全な dd ディスクイメージから MBR を取得することもできます:
You can also get the MBR from a full dd disk image.
 
# dd if=/path/to/disk.img of=/mnt/sda1/mbr.img bs=512 count=1
+
# dd if=/path/to/disk.img of=/path/to/mbr_file.img bs=512 count=1
   
 
=== ディスクイメージの作成 ===
 
=== ディスクイメージの作成 ===
   
1. Boot from a liveCD or liveUSB.
+
1. liveCD liveUSB から起動。
   
 
2. Make sure no partitions are mounted from the source hard drive.
 
2. Make sure no partitions are mounted from the source hard drive.
79行目: 79行目:
   
 
4. Backup the drive.
 
4. Backup the drive.
# dd if=/dev/hda conv=sync,noerror bs=64K | gzip -c > /mnt/sda1/hda.img.gz
+
# dd if=/dev/sd''X'' conv=sync,noerror bs=64K | gzip -c > ''/path/to/backup.img.gz''
   
 
If necessary (e.g. when the format of the external HD is FAT32) split the disk image in volumes (see also split man pages).
 
If necessary (e.g. when the format of the external HD is FAT32) split the disk image in volumes (see also split man pages).
   
# dd if=/dev/hda conv=sync,noerror bs=64K | gzip -c | split -a3 -b2G - /mnt/sda1/hda.img.gz
+
# dd if=/dev/sd''X'' conv=sync,noerror bs=64K | gzip -c | split -a3 -b2G - ''/path/to/backup.img.gz''
   
 
5. Save extra information about the drive geometry necessary in order to interpret the partition table stored within the image. The most important of which is the cylinder size.
 
5. Save extra information about the drive geometry necessary in order to interpret the partition table stored within the image. The most important of which is the cylinder size.
# fdisk -l /dev/hda > /mnt/sda1/hda_fdisk.info
+
# fdisk -l /dev/sd''X'' > ''/path/to/list_fdisk.info''
   
{{Note|1=You may wish to use a block size (bs=) that is equal to the amount of cache on the HD you are backing up. For example, bs=8192K works for an 8MB cache. The 64K mentioned in this article is better than the default bs=512 bytes, but it will run faster with a larger bs=.}}
+
{{Note|You may wish to use a block size ({{ic|1=bs=}}) that is equal to the amount of cache on the HD you are backing up. For example, {{ic|1=bs=8192K}} works for an 8MB cache. The 64K mentioned in this article is better than the default {{ic|1=bs=512}} bytes, but it will run faster with a larger {{ic|1=bs=}}.}}
   
 
=== システムのリストア ===
 
=== システムのリストア ===
   
 
システムをリストアするには:
 
システムをリストアするには:
# gunzip -c /mnt/sda1/hda.img.gz | dd of=/dev/hda
+
# gunzip -c ''/path/to/backup.img.gz'' | dd of=/dev/sd''X''
   
 
もしくはイメージが複数のボリュームに分かれている場合:
 
もしくはイメージが複数のボリュームに分かれている場合:
# cat /mnt/sda1/hda.img.gz* | gunzip -c | dd of=/dev/hda
+
# cat ''/path/to/backup.img.gz*'' | gunzip -c | dd of=/dev/sd''X''
   
 
=== 圧縮 ===
 
=== 圧縮 ===
106行目: 106行目:
 
Install the {{Pkg|p7zip}} package from the [[official repositories]].
 
Install the {{Pkg|p7zip}} package from the [[official repositories]].
 
This backup example will split the ''dd'' command output in the files by up to the 100 megabyte each:
 
This backup example will split the ''dd'' command output in the files by up to the 100 megabyte each:
dd if=/dev/sdXY | 7z a -v100m -t7z -si image-file.7z
+
# dd if=/dev/sd''XY'' | 7z a -v100m -t7z -si image-file.7z
   
 
Restore with 7zip:
 
Restore with 7zip:
7z x -so image-file.7z | dd of=/dev/sdXY
+
# 7z x -so image-file.7z | dd of=/dev/sd''XY''
 
{{Note|7zip can split only the ''7z'' compression type files}}
 
{{Note|7zip can split only the ''7z'' compression type files}}
   
117行目: 117行目:
 
It will create a file with "-" name inside the image-file.zip file which will contain data from the ''dd'' command output. To make a raw output of the file you can use the {{ic|-cp}} option with ''unzip'' in stdout for the ''dd'' command.
 
It will create a file with "-" name inside the image-file.zip file which will contain data from the ''dd'' command output. To make a raw output of the file you can use the {{ic|-cp}} option with ''unzip'' in stdout for the ''dd'' command.
 
Backup:
 
Backup:
dd if=/dev/sdXY | zip --compression-method bzip2 image-file.zip -
+
# dd if=/dev/sd''XY'' | zip --compression-method bzip2 ''image-file.zip'' -
   
 
Restore:
 
Restore:
unzip -cp image-file.zip | dd of=/dev/sdXY
+
# unzip -cp image-file.zip | dd of=/dev/sd''XY''
   
 
The ''zip'' tool cannot split files on the fly but you can use the {{ic|zipsplit}} utility on an already created file.
 
The ''zip'' tool cannot split files on the fly but you can use the {{ic|zipsplit}} utility on an already created file.
133行目: 133行目:
   
 
This should do a backup and split the creating file on the fly in by up to 150 megabyte files each.
 
This should do a backup and split the creating file on the fly in by up to 150 megabyte files each.
dd if=/dev/sdXY | rar a -v150m -siimage-file.rar
+
# dd if=/dev/sd''XY'' | rar a -v150m -si''image-file.rar''
   
 
This should restore
 
This should restore
unrar x -p image-file.rar | dd of=/dev/sdXY
+
# unrar x -p ''image-file.rar'' | dd of=/dev/sd''XY''
   
 
or you can use the ''rar'' instead of the {{Pkg|unrar}} utility. The unrar utility is available in the official repositories and can be installed with {{ic|pacman -S unrar}}.
 
or you can use the ''rar'' instead of the {{Pkg|unrar}} utility. The unrar utility is available in the official repositories and can be installed with {{ic|pacman -S unrar}}.
144行目: 144行目:
 
Creation by using the ''dd'' is more safe and use to be error free:
 
Creation by using the ''dd'' is more safe and use to be error free:
   
{{hc|<nowiki>dd if=/dev/sdXY | bzip2 -f5 > compressedfile.bzip2</nowiki>|
+
{{hc|1=# dd if=/dev/sd''XY'' <nowiki>|</nowiki> bzip2 -f5 > ''compressedfile.bzip2''|2=
 
937016+0 records in
 
937016+0 records in
 
937016+0 records out
 
937016+0 records out
151行目: 151行目:
   
 
And a safe way of restoring with combination of the ''dd'':
 
And a safe way of restoring with combination of the ''dd'':
$ bunzip2 -dc compressedfile.bzip2 | dd of=/dev/sdXY
+
# bunzip2 -dc ''compressedfile.bzip2'' | dd of=/dev/sd''XY''
   
 
or
 
or
$ bzcat compressedfile.bzip2 | dd of=/dev/sdXY
+
# bzcat ''compressedfile.bzip2'' | dd of=/dev/sd''XY''
   
{{Warning|Never ever use the {{ic|bzip2 -kdc imgage.bzip2 > /dev/sdXY}} and {{ic|bzip2 -kc /dev/sdXY > imgage.bzip2}} methods for serious backup of partitions and disks. The errors might be due the end of the device or partition and the restore process gives also errors due the truncated end.
+
{{Warning|Never ever use the {{ic|bzip2 -kdc ''imgage.bzip2'' > /dev/sd''XY''}} and {{ic|bzip2 -kc /dev/sd''XY'' > ''imgage.bzip2''}} methods for serious backup of partitions and disks. The errors might be due the end of the device or partition and the restore process gives also errors due the truncated end.
 
}}
 
}}
   
168行目: 168行目:
 
* Create the new destination partition(s) using fdisk, cfdisk or other tools available in the live environment.
 
* Create the new destination partition(s) using fdisk, cfdisk or other tools available in the live environment.
 
* Create a filesystem on each of the newly created partitions. Example:
 
* Create a filesystem on each of the newly created partitions. Example:
mkfs -t ext3 /dev/sdb1
+
# mkfs -t ext3 /dev/sd''XY''
 
* Mount the source and destination partitions. Example:
 
* Mount the source and destination partitions. Example:
mount -t ext3 /dev/sda1 /mnt/source
+
# mount -t ext3 /dev/sd''XY'' ''/mnt/source''
mount -t ext3 /dev/sdb1 /mnt/destination
+
# mount -t ext3 /dev/sd''ZY'' ''/mnt/destination''
 
* Copy the files from the source partition to the destination
 
* Copy the files from the source partition to the destination
cp -a /mnt/source/* /mnt/destination
+
# cp -a ''/path/to/source/*'' ''/path/to/destination''
 
'''-a''': preserve all attributes, never follow symbolic links and copy recursively
 
'''-a''': preserve all attributes, never follow symbolic links and copy recursively
* Change the mount points of the newly cloned partitions in /etc/fstab accordingly
+
* Change the mount points of the newly cloned partitions in {{ic|/etc/fstab}} accordingly
 
* Finally, install the GRUB bootloader if necessary. (See [[GRUB]])
 
* Finally, install the GRUB bootloader if necessary. (See [[GRUB]])
   
182行目: 182行目:
 
=== Arch でディスククローン ===
 
=== Arch でディスククローン ===
   
* [[Partclone|Partclone]] provides utilities to save and restore used blocks on a partition and supports ext2, ext3, ext4, hfs+, reiserfs, reiser4, btrfs, vmfs3, vmfs5, xfs, jfs, ufs, ntfs, fat(12/16/32) and exfat. Optionally, a ncurses interface can be used. Partclone is available in the community repository.
+
* [[Partclone]] にはパーティション上の使用されているブロックを保存・復旧するためのユーティリティが入っており ext2, ext3, ext4, hfs+, reiserfs, reiser4, btrfs, vmfs3, vmfs5, xfs, jfs, ufs, ntfs, fat(12/16/32), exfat がサポートされています。オプションで、ncurses インターフェイスを使うこともできます。Partclone community リポジトリからインストールできます。
 
* [http://www.partimage.org/ Partimage], an ncurses program, is available in the community repos. Partimage does not currently support ext4 or btrfs filesystems. NTFS is experimental.
 
* [http://www.partimage.org/ Partimage], an ncurses program, is available in the community repos. Partimage does not currently support ext4 or btrfs filesystems. NTFS is experimental.
   
199行目: 199行目:
   
 
* [[Wikipedia:List of disk cloning software]]
 
* [[Wikipedia:List of disk cloning software]]
* [https://bbs.archlinux.org/viewtopic.php?id=4329 Arch Linux forum thread]
+
* [https://bbs.archlinux.org/viewtopic.php?id=4329 Arch Linux フォーラムスレッド]

2015年4月6日 (月) 18:46時点における版

ディスクのクローンとはパーティションやハードドライブ全体のイメージを作成することを言います。バックアップリカバリ用に他のコンピューターにドライブをコピーするのに役立ちます。

dd を使う

dd コマンドはシンプルでありながら、多目的に使える強力なツールです。ファイルシステムのタイプやオペレーティングシステムとは関係なく、ブロックごとに、コピーを行うことができます。ライブ CD などの、ライブ環境から dd を使用すると便利です。

警告:
  • This paragraph used to contain several errors that misrepresented the inner workings of the dd command. I tried to fix them, but YMMV.
  • As with any command of this type, you should be very cautious when using it; it can destroy data. Remember the order of input file (if=) and output file (of=) and do not reverse them! Always ensure that the destination drive or partition (of=) is of equal or greater size than the source (if=).

パーティションのクローン

物理ディスク /dev/sda のパーティション 1 を、物理ディスク /dev/sdb のパーティション 1 に複製。

# dd if=/dev/sda1 of=/dev/sdb1 bs=512 conv=noerror,sync
警告: If output file of= (sdb1 in the example) does not exist, dd will create a file with this name and will start filling up your root file system.

ハードディスク全体のクローン

物理ディスク /dev/sdX を物理ディスク /dev/sdY に複製:

# dd if=/dev/sdX of=/dev/sdY bs=512 conv=noerror,sync

このコマンドは MBR (とブートローダー)、全てのパーティション、UUID、データを含めディスクの全てを複製します。

  • noerror は読み取りエラーを全て無視して操作を続行します。dd のデフォルトの挙動ではエラーがあると dd は動作を停止します。
  • sync は読み取りエラーが存在した場合、入力ブロックをゼロで埋めるため、データのオフセットも同期します。
  • bs=512 sets the block size to 512 bytes, the "classic" block size for hard drives. If and only if your hard drives have a 4K block size, you may use "4096" instead of "512". Also, please read the warning below, because there is more to this than just "block sizes" - it also influences how read errors propagate.
警告: The block size you specify influences how read errors are handled. Read below.

The dd utility technically has an "input block size" (IBS) and an "output block size" (OBS). When you set bs, you effectively set both IBS and OBS. Normally, if your block size is, say, 1M, dd will read 1M bytes and write 1M bytes. But if a read error occurs, things will go wrong. Many people seem to think that dd will "fill up read errors with zeroes" if you use the noerror,sync options, but this is not what happens. dd will, according to documentation, fill up the OBS to IBS size, which means adding zeroes at the end of the block. This means, for a disk, that effectively the whole 1M would become messed up because of a single 512 byte read error in the beginning of the read: ERROR6789 would become 678900000 instead of 000006789.

If you are positive that your disk does not contain any errors, you could proceed using a larger block size, which will increase the speed of your copying manifold. For example, changing bs from 512 to 64K changed copying speed from 35MB/s to 120MB/s on a simple Celeron 2.7GHz system. But keep in mind, that read errors on the source disk will end up as block errors on the destination disk, i.e. a single 512 bytes read error will mess up the whole 64k output block.

ヒント: If you would like to view dd progressing, you can send it a USR1 signal. pidof dd will tell you the PID of dd, then use kill -USR1. In one line: kill -USR1 $(pidof dd).
ノート:
  • To regain unique UUIDs of an Ext2/3/4 filesystem, use tune2fs /dev/sdXY -U random on every partitions.
  • Partition table changes from dd are not registered by the kernel. To notify of changes without rebooting, use a utility like partprobe (part of GNU parted).

MBR のバックアップ

MBR はディスクの頭512バイトに保存されています。MBR は3つの構成部位から成ります:

  1. 最初の446バイトにはブートローダーが含まれます。
  2. 次の64バイトにはパーティションテーブルが含まれます (16バイトごとに4エントリ、1つのエントリに1つのプライマリパーティション)。
  3. 最後の2バイトには識別子が含まれます。

MBR を "mbr.img" ファイルに保存するには:

# dd if=/dev/sdX of=/path/to/mbr_file.img bs=512 count=1

リストアするには (be careful: this could destroy your existing partition table and with it access to all data on the disk):

# dd if=/path/to/mbr_file.img of=/dev/sdX

ブートローダーだけをリストアして、プライマリパーティションテーブルのエントリはそのままにしたい場合、MBR の最初の446バイトだけをリストアしてください:

# dd if=/path/to/mbr_file.img of=/dev/sdX bs=446 count=1

パーティションテーブルだけをリストアするには、次のコマンドを使用します:

# dd if=/path/to/mbr_file.img of=/dev/sdX bs=1 skip=446 count=64

完全な dd ディスクイメージから MBR を取得することもできます:

# dd if=/path/to/disk.img of=/path/to/mbr_file.img bs=512 count=1

ディスクイメージの作成

1. liveCD や liveUSB から起動。

2. Make sure no partitions are mounted from the source hard drive.

3. Mount the external HD

4. Backup the drive.

# dd if=/dev/sdX conv=sync,noerror bs=64K | gzip -c  > /path/to/backup.img.gz

If necessary (e.g. when the format of the external HD is FAT32) split the disk image in volumes (see also split man pages).

# dd if=/dev/sdX conv=sync,noerror bs=64K | gzip -c | split -a3 -b2G - /path/to/backup.img.gz

5. Save extra information about the drive geometry necessary in order to interpret the partition table stored within the image. The most important of which is the cylinder size.

# fdisk -l /dev/sdX > /path/to/list_fdisk.info
ノート: You may wish to use a block size (bs=) that is equal to the amount of cache on the HD you are backing up. For example, bs=8192K works for an 8MB cache. The 64K mentioned in this article is better than the default bs=512 bytes, but it will run faster with a larger bs=.

システムのリストア

システムをリストアするには:

# gunzip -c /path/to/backup.img.gz | dd of=/dev/sdX

もしくはイメージが複数のボリュームに分かれている場合:

# cat /path/to/backup.img.gz* | gunzip -c | dd of=/dev/sdX

圧縮

When you need to create the hard drive or a single partition compressed backup image file you must use compression tools which can do backup from a stdout and the dd command. Those compressed files cannot be mounted by the mount command but are useful to know how to create and restore them.

7zip

Install the p7zip package from the official repositories. This backup example will split the dd command output in the files by up to the 100 megabyte each:

# dd if=/dev/sdXY | 7z a -v100m -t7z -si image-file.7z

Restore with 7zip:

# 7z x -so  image-file.7z | dd of=/dev/sdXY
ノート: 7zip can split only the 7z compression type files

Zip

Install the zip package from the official repositories, which contains zipsplit among other utilities for the management of zip archives. It will create a file with "-" name inside the image-file.zip file which will contain data from the dd command output. To make a raw output of the file you can use the -cp option with unzip in stdout for the dd command. Backup:

# dd if=/dev/sdXY | zip --compression-method bzip2 image-file.zip - 

Restore:

# unzip -cp image-file.zip | dd of=/dev/sdXY

The zip tool cannot split files on the fly but you can use the zipsplit utility on an already created file.

See also man zip for more information.

Rar

Install the rarAUR package from the AUR.

警告: The rar examples were made based on the manuals, please confirm!

This should do a backup and split the creating file on the fly in by up to 150 megabyte files each.

# dd if=/dev/sdXY | rar a -v150m -siimage-file.rar

This should restore

# unrar x -p image-file.rar | dd of=/dev/sdXY

or you can use the rar instead of the unrar utility. The unrar utility is available in the official repositories and can be installed with pacman -S unrar.

Bzip2

Creation by using the dd is more safe and use to be error free:

# dd if=/dev/sdXY | bzip2 -f5 > compressedfile.bzip2
937016+0 records in
937016+0 records out
479752192 bytes (480 MB) copied, 94.7002 s, 5.1 MB/s

And a safe way of restoring with combination of the dd:

# bunzip2 -dc compressedfile.bzip2 | dd of=/dev/sdXY

or

# bzcat compressedfile.bzip2 | dd of=/dev/sdXY
警告: Never ever use the bzip2 -kdc imgage.bzip2 > /dev/sdXY and bzip2 -kc /dev/sdXY > imgage.bzip2 methods for serious backup of partitions and disks. The errors might be due the end of the device or partition and the restore process gives also errors due the truncated end.

cp を使う

The cp program can be used to clone a disk, one partition at a time. An advantage to using cp is that the filesystem type of the destination partition(s) may be the same or different than the source. For safety, perform the process from a live environment.

ノート: This method should not be considered in the same category as disk cloning on the level at which dd operates. Also, it has been reported that even with the -a flag, some extended attributes may not be copied. For better results, rsync or tar should be used.

The basic procedure from a live environment will be:

  • Create the new destination partition(s) using fdisk, cfdisk or other tools available in the live environment.
  • Create a filesystem on each of the newly created partitions. Example:
# mkfs -t ext3 /dev/sdXY
  • Mount the source and destination partitions. Example:
# mount -t ext3 /dev/sdXY /mnt/source
# mount -t ext3 /dev/sdZY /mnt/destination
  • Copy the files from the source partition to the destination
# cp -a /path/to/source/* /path/to/destination

-a: preserve all attributes, never follow symbolic links and copy recursively

  • Change the mount points of the newly cloned partitions in /etc/fstab accordingly
  • Finally, install the GRUB bootloader if necessary. (See GRUB)

ディスククローンソフトウェア

Arch でディスククローン

  • Partclone にはパーティション上の使用されているブロックを保存・復旧するためのユーティリティが入っており ext2, ext3, ext4, hfs+, reiserfs, reiser4, btrfs, vmfs3, vmfs5, xfs, jfs, ufs, ntfs, fat(12/16/32), exfat がサポートされています。オプションで、ncurses インターフェイスを使うこともできます。Partclone は community リポジトリからインストールできます。
  • Partimage, an ncurses program, is available in the community repos. Partimage does not currently support ext4 or btrfs filesystems. NTFS is experimental.

Arch の外からディスククローン

If you wish to backup or propagate your Arch install root, you are probably better off booting into something else and clone the partition from there. Some suggestions:

  • PartedMagic has a very nice live cd/usb with PartImage and other recovery tools.
  • Mindi is a linux distribution specifically for disk clone backup. It comes with its own cloning program, Mondo Rescue.
  • Acronis True Image is a commercial disk cloner for Windows. It allows you to create a live (from within Windows), so you do not need a working Windows install on the actual machine to use it. After registration of the Acronis software on their website, you will be able to download a Linux based Live cd and/or plugins for BartPE for creation of the Windows based live cd. It can also create a WinPE Live CD based on Windows. The created ISO Live CD image by Acronis doesn't have the hybrid boot ability and cannot be written to USB storage as a raw file.
  • FSArchiver allows you to save the contents of a file system to a compressed archive file. Can be found on the System Rescue CD.
  • Clonezilla is an enhanced partition imager which can also restore entire disks as well as partitions. Clonezilla is included on the Arch Linux installation media.
  • Redo Backup and Recovery is a Live CD featuring a graphical front-end to partclone.

参照