Linux: dump and restore mini-HOWTO <author> FUKUSHIMA Osamu, (福島於修), <<tt/> <date> 2.0, 16 Aug. 2000 <!-- $Id --> <abstract> <!--O この文書は BSD 由来のツール dump(8) および restore(8) の利用方法と テープドライブのオペレーションに関することを解説するものです。 バックアップ作業全般に関する注意点にも触れています。 --> This document explains how to use dump(8) and resotre(8), which are the tools of BSD origin, and how to operate tape drives. It also treats general matters in the backup operations. </abstract> <toc> <sect>dump/restore: Overview <p> <!--O dump(8) と restore(8) は、 BSD 系 UNIX で伝統的に使われてきた、 ファイルシステムのバックアップ・レストアのためのプログラムです。 --> dump(8) and restore(8) are BSD derived programs which backup and restore the filesystem. <p> <!--O dump はファイルシステムをバックアップし、 restore はバックアップされたアーカイヴ(書庫)からファイルを復元します。 アーカイヴは普通のファイルとして、 通常のファイルシステムに作成することができますが、 一般的にはバックアップ専用の外部デバイス (テープデバイスなど) に 保存することが多く、dump コマンドにはそのための利便も用意されています。 --> Dump command backups the filesystem, and restore command restores files from the ``archive'' backuped previously. The archive may be created as a regular file on usual filesystem, but it is common to be preserved on some external backup device (e.g. tape device). Dump command has useful features for these devices. <!--O <sect1>他のアーカイヴソフトとの比較 --> <sect1>Comparison with other archiving softwares <p> <!--O アーカイヴを作成するソフトウェアとしては、他に cpio, tar, afio といったもの があります。これらのソフトウェアはファイル単位でアーカイヴのターゲットを認識 します。したがって特定のファイルやディレクトリをアーカイヴする対象から除外し たり、複数のファイルシステムにまたがって単一のアーカイヴを作成することもでき ます。 --> There are another archiving programs, such as cpio, tar, afio, etc. Most of these treat the files as the archiving targets. Therefore, they can exclude specific files and/or directories from the archiving task, or can create a single archive for multiple filesystems. <p> <!--O 一方 dump は物理的なファイルシステム単位でターゲットを認識します。そして、個々 のファイルは i-node の単位で処理されます。特定のファイルをアーカイヴの対象か ら除外するような機能は用意されていません。(これに関しては、別の方法で同じよ うな効果を得ることもできます。詳しくは後述する <ref id="exclude" name="バックアップしないファイルを除外する"> を参照してください。) --> On the other hand, dump recognizes the whole (physical) filesystem as the archiving target. And each file is treated base on its i-node. It cannot exclude specific file from the archive (however, you can do the same thing with another way. See <ref id="exclude" name="Exclude specific files from backup">). <p> <!--O そのかわり、dump はインクリメンタルアーカイヴ(前回のアーカイヴ時点から更 新されたファイルだけを選び出してアーカイヴする)の機能に関しては、たいへん すぐれた機構を提供しています。また、インクリメンタルアーカイヴに要する時間 も、他の方法にくらべて非常に高速です。 --> Instead, dump has nice mechanisms for the incremental archiving (the feature to archive only new/modified files after the previous backup). And on the incremental archiving, it is much faster than other methods. <p> <!--O restore は dump を使ってしたアーカイヴファイルを元に、その dump 作業を行っ た時の状態にファイルシステムを復元しようとします。 --> Restore uses the archive created by dump, and try to bring back the filesystem to the state when the archive was generated. <p> <!--O 例えば前回のアーカイヴ時に存在した foo というファイルが、その後不要になっ て削除されたとします。次のインクリメンタルアーカイヴの時点では foo は存在 しないので、dump は「foo というファイルがあったけど、これは削除されています」 という情報をインクリメンタルのアーカイヴファイルに残します。 --> For example, imagine a file foo was backuped in previous archiving, and then removed after that. At the next incremental archiving, dump records the information "There was a file foo, but has been removed.' in the incremental archive file. <p> <!--O tar を使ってインクリメンタルバックアップを続けていて、ある日全てをフルレスト アしてみたら、はるか昔に消したはずのファイルがいっぱいで、ファイルシステムが 溢れてしまった、という事態には決してなりません。 --> If you use tar for incremental archiving, you may have a number of files already removed in those archives. So when you restore the full filesystem with these someday, you may run out of whole diskspace with these files. With dump, you never experience such a situation. <p> <!--O 以上のことをまとめると、 --> In summary, <itemize> <item> <!--O 特定のディレクトリやファイルをアーカイヴするには、 cpio, tar, afio などが向いている --> You should use cpio, tar or afio to archive specific files or directories. <item> <!--O ファイルシステムのアーカイヴには、dump が向いている --> You should use dump to archive the filesystem. </itemize> <!--O といえます。目的に応じて、これらのツールを使い分けるとよいでしょう。この文書 は dump/restore に関する物なので、以下に記述されているのは、ファイルシステム のバックアップに関することであると考えてください。 --> You should be advised to select the tool for your purpose. This howto document accounts dump/restore, so please consider that the following explanation is related to the backup of the filesystem. <!--O <sect1>他のバックアップソフトとの比較 --> <sect1>Comparison with other backup programs <p> <!--O dump は tar と同様にファイルをアーカイヴする機能がありますが、それ自体がバッ クアップソフトでもあります。ところで、Linux のバイナリディストリビューション にはバックアップ専用のユーティリティーが付属していることがあります。さまざま な種類のユーティリティーがありますが、外部のアーカイヴツールのフロントエンド として動作するものが多いようです。すべてを実際に使ってみたわけではありません が、メニュー形式でセットアップができるものもあり、なかなか便利に思えます。 --> Dump has the feature to archive files (as tar), but is also a backup software by itself. By the way, some Linux distributions have various utilities for backup, most of which works as front-ends of external archiving programs. I didn't try all of them, but some of them have nice-looking menu support for the setup of the backup. <p> <!--O これまで、私も何度かそういうユーティリティーを使ってみようかと考えましたが、 結局使わないまま今日にいたっています。ひとつには、すでに dump/restore に慣れ てしまっているので、新しいソフトウェアの使用方法を覚えるのが面倒に感じられる、 ということがあります。しかし、結局のところは「単純なものの方が信頼できる」と いう一点につきるようです。dump で保存したバックアップが必要になる状況は、い わは緊急事態といえます。システムそのものが起動しない状況さえも想定しておかな ければなりません。そう考えると、あまりきちんと整った環境でなくても動作するこ とが期待できるツールの方が何かと都合がいいと思うのです。 --> I considered to use this kind of utility several times, but have continued to use dump/restore after all. For one reason, I'm already familiar with dump/resotre, and don't want to learn these new software. But more important reason is that "more simple, more reliable". The situation where the backup is necessary is something like emergency. You should even assume that the system itself does not boot. Therefore, I think that the simple system, which does not need proper environment, is suitable for the restoration. <p> <!--O 私は initrd を利用した緊急起動用のフロッピーディスクを一枚つくって用意してい ます。こういうディスクを実際に作ってみるとわかるのですが、たとえ initrd を利 用しても容量は実に限られています。私の作ったディスクには、周囲にある数台のマ シンをカバーする、いわゆるジェネリックなカーネルと、いくつかのデバイスドライ バのモジュール、そして fdisk, fsck, ed, tar などの基本的な修復のための ツールとともに mt や restore が入っています。まだ実際に役に立ったことはありませんが、このディ スクから起動したシステムでローカルあるいはリモート接続のテープドライブが駆動 できることを確認してあります。正直いって、このフロッピーディスクを作る作業は あまり楽しいものとは言えませんでした。しかし、このフロッピー一枚だけで、必要 とあらばファイルシステムの再構築ができることが確認できたとき、大きな安心感が 得られました。 --> I have prepared one emergency floppy with initrd. As you also will see if you try to make this kind of disk, you only have very limited space even using initrd. My floppy contains some kind of generic kernel, which supports several machines around me, some driver modules, basic command (i.e. fdisk, fsck, ed, tar...) required for the system recovery, mt command and resotre. I have not encountered the situation where this floppy actually works, but I made sure this floppy can boot the system and run the tape drive (either local or remote). Frankly, it was not a interesting work to create this floppy disk. However, when I confirmed that the whole file system could be recovered with this single floppy, I had a very good feeling. <p> <!--O dump/restore 以外のバックアップ方法を否定するものではありませんが、個人的に はファイルシステムの復旧時にあまりおおげさなツールを必要とする方法はおすすめ しません。バックアップツールを選択するときには、このことを頭の片隅にとめてお いてください。 --> Of course I don't contradict the backup methods other than dump/resotre, but I don't recommend the system which requires enormous system. Please not this when you select your backup tool. <!-- <quote> [FYI: 1999/07/30]<newline> Wil Mahan 氏 <<tt/> が作成・配布している <htmlurl url="" name="ibs (The Intelligent Backup System)"> というバックアップするユーティリティーが登場しました。 インストール後に変更されたファイルだけをバックアップ/レストアできることが 最大の特徴です。 現在は Debian GNU/Linux systems だけを対象にしていますが、 将来的には RPM ベースで配布されるディストリビューションも ターゲットにする予定とのことです。 </quote> --> <!--O <sect>メディアに関すること --> <sect>Backup Media <p> <!--O 最近は大容量のハードディスクドライブがたいへん安価に入手できるので、バックアッ プ専用のメディアとしてこれを選択することは、それほど非現実的なことではありま せん。ハードウェアとしてのメンテナンスも楽ですし、アーカイヴが目に見える形で 保管できるのもメリットといえるでしょう。 --> Recently, the capacity of the hard disk drive grows steeply, while its price becomes rather cheeper. So you may want to use HDD as the backup media. It also has nice features: it's easy to maintenance it, and you can see how the arcihves are stored in it. <p> <!--O もし、バックアップの対象となるディスクの容量が比較的小さいならば、バックアッ プメディアとしてハードディスクドライブを使用することをおすすめします。あるい は、今すぐにテープドライブなどの専用デバイスを購入することがためらわれる場合 に、とりあえずハードディスクドライブで間に合わせるというのもよいでしょう。後 で専用デバイスを入手したときでも、ディスクは無駄にすることなく、通常のファイ ルシステムとして使い続けることができるからです。 --> If the capacity of the target disk is not so large, I recommend you to use HDD as a backup media. Or if it is difficult to purcahse the backup-specific hardware (tape drive, etc.), it is not a bad idea to start with HDD for the meantime. When you get a specific hardware in the future, you can turn it to an usual filesystem anyway. <p> <!--O バックアップの対象となるディスクの容量が大きいなら、バックアップ専用のデバ イスの購入は検討に値します。テープは当然リムーバブルなので、低コスト で過去のバックアップについての履歴を保存することができるようになります。 --> If the capacity of the backup target is somewhat large, you should consider to purchase a backup specific device. Since tape media is removable generally, you can preserve the history of a series of backups with low cost. <p> <!--O dump でのバックアップには、一般的にはテープカートリッジが使われています。PC では、QIC(1/4 inch cartridge), 4mm DAT, 8mm EXABYTE, DLT (Digital Linear Tape) などがよく使われています。 --> Tape cartridge is a popular media for the backup using dump. With PC, QIC (quater inch cartridge), 4mm DAT, 8mm EXABYTE and DLT (Digital Linear Tape) are the common choice. <p> <!--O わたしは EXABYTE の EXB-8505 という古い SCSI1 のテープドライブを使っています。 EXABYTE は 8mm ビデオテープに似た専用のカートリッジテープを使用します。 ドライブやメディアの価格が高いのが難点で、 個人が使用するにはあまり向いているとはいえません。 しかし、大容量のバックアップメディアとして長く使われており、 信頼性も高いといえます。 --> I'm using a EXABYTE EXB-8505, rather old SCSI1 tape drive. It uses special cartridge tape which looks like 8mm VCR tape. Both drive and media are rather expensive, so it's not suitable for private usage. But it has been used for long time, and can be considered to be fairly reliable. <p> <!--O 8mm EXABYTE の機構を小型化したようなものが 4mm DDS ドライブです。 比較的安価 (新品が 3 万円ほど売られていることもあります)で しかも容量が大きいので人気があります。 取り扱いも楽で駆動音も静かです。ヘッドの寿命が短いという人もいます。 --> 4mm DDS drive is a compact drive which has the same mechanism with 8mm EXABYTE device. It is popular since it is inexpensive (you can find some with 30,000 yen or so) and has fairly large capacity. It is easy to handle and works quietly. But someone say that the lifetime of the head is rather short. <p> <!--O 目安としては、稼働しているファイルシステムのうちもっともサイズの大きな領域が、 分割せずに余裕をもって収まるくらいの容量のあるメディアを選ぶべきです。 --> Recommendation: you should choose the media which has the capacity to store your largest filesystem as a whole. <p> <!--O テープドライブ全般に関する情報へのポインタとして: --> You can find more general information for tape drives at: <quote> <tt> <htmlurl url="" name=""> </tt> <newline> ``The Source of All Knowledge (英文)'' </quote> <!--O と、ここからたどれるリンクをあげておきます。 --> and links given there. <p> <!--O この文書では、8mm テープドライブ EXB-8200 を例にして、テープ上にバッ クアップ・アーカイヴを作成することを解説していきます。 --> In the following part of this document, I explain how to create backup archives on tapes, and EXB-8200 tape drive is used as the example. <!--O <sect>Linux での利用 --> <sect>Use dump/resotre with Linux <sect1>dump/restore v0.3 <p> <!--O Linux では Remy Card 氏 (<tt/ が 4.4BSD の物をベースに移植した 物が使われています。Red Hat や Debian には、dump-0.3 のバイナリパッケージが 付属しています。 ソースパッケージは: --> There is a dump/restore for Linux ported by Remy Card (<tt/ based on the one in 4.4BSD. Red Hat and Debian have their binary packages of dump-0.3. Source archive is available at: <quote> <tt> <htmlurl url="" name=""> </tt> </quote> <!--O から入手できます。 LSM ファイルには 2.0.x 以降のカーネルについての 記述がありませんが、これらの新しいカーネルを走らせているシステムでも 問題なく利用できるはずです。 dump プログラムは ext2 ファイルシステムの 構造に依存しているので、 自分で make するためには Ext2fs library が必要です。 このライブラリも上記のディレクトリから入手可能です。 --> There is no description in the LSM file about the compatibility with the 2.0.x (or later) version of Linux kernel, you should use it with no problem on the system with these new kernels. Since dump depends on the structure of the ext2 filesystem, you need Ext2fs library to compile it by yourself. This library is also available from the URL directory abov3. <p> <!--O dump が ext2 ファイルシステムの構造に依存していることは、 いくつかの制限をもたらしています。 --> Dump has some limitations because of its dependency on the ext2 filesystem: <p> <!--O まず Peter Moulder 氏 (<tt/ が公開している ext2 ファイルシステムへの拡張機能 (e2compr) を使って圧縮されたファイルは、 正常に restore できないことがわかっています (正確にいえば、圧縮されているかどうかを保存しているクラスタービットが 復元されないために、圧縮されたデータへの透過的なアクセスができなくなります)。 --> One is that it cannot properly resotre the file compressed by the e2compr, which is the extention to the ext2 filesystem developed by Peter Mounlder (<tt/ More concretely, on-the-fly access to the compressed data will not be available since the cluster bit, which tells the data is compressed or not, is not recovered. <p> <!--O したがって、現状では e2compr を利用する場合は dump 以外の バックアップ手段を選ばなければなりません。 --> For e2compr, therfore, you have to choose the backup system except for dump currently. <p> <!--O もうひとつの制限は、dump バージョン 0.3 はマルチボリュームの バックアップを公式にはサポートしていないことです。 したがってバックアップメディアのサイズがファイルシステムのサイズよりも小さい 場合には、正常にレストアできない可能性もあります。 --> Another limitation is that dump version 0.3 does not support the multivolume backup (at least officially). Hence if the size of the backup media is smaller than that of the filesystem, it is possible you cannot restore it properly. <sect1>dump/restore v0.4 Beta <p> <!--O 1996 年 1 月には、4.4BSD-Lite2 の dump をベースに移植した、新しい dump-0.4 のβバージョンがテスト公開されています。 このシリーズは 0.4b4 まで Remy Card 氏 によって作成・配布されて きましたが、その後数年間に渡ってメンテナンスが停止状態になっていました。 --> In January 1996, new dump-0.4 beta version has been released for testing. It was ported from the dump in 4.4BSD-Lite2. This series was maintained and distributed by Remy Card until 0.4b, but has been unmaintained for a few years after that. <p> <!--O 1999 年 9 月に Stelian Pop 氏 (<tt/ によって 開発が引き継がれることになり、現在正式公開に向けてβバージョンが出ています。 このβバージョンは: --> In September 1999, Stelian Pop (<tt/ have taken over the development, and have still been working for the official release. Now the beta version for this is available at: <quote> <tt> <htmlurl url="" name=""> </tt> </quote> <!--O で入手することができます。このバージョンでは、マルチボリュームの バックアップがサポートされています。 その他にも dump/restore の 0.4b は、0.3 と比較すると数多くの Bugfix と 新しい機能の追加が行われています。主なものは: --> In this version, the multivolume backup is supported. Dump/resotre 0.4b has more new features (with many bugfixes) compared to 0.3, which includes (as of 2000/07/05): <itemize> <!--O <item>FreeBSD-3.1-RELEASE で行われた Bugfix と機能追加の輸入 <item>Red Hat, Debian, SuSE が作成したパッチの取り込み <item>マルチボリュームのアーカイヴの取り扱いに関する Bugfix 類 <item>リモートバックアップ時に rsh 以外の remote shell を使えるようになった <item>ext3 ファイルシステムへの対応 <item>kerberos サポート <item>buffer overflow 問題の解決 <item>dump 終了時に特定の command を実行できるようになった (-F) <item>restore するファイル名のリストを外部から読み込めるようになった (-X) <item>restore の対話モードでの GNU readline サポート --> <item>Import new features and bugfixes achieved on FreeBSD-3.1-RELEASE <item>Apply patches by Red Hat, Debian and SuSE <item>Bugfixes relating to the multivolume archive handling <item>Remote backup is available with any remote shell <item>Support ext3 filesystem <item>Support kerberos <item>Fix buffer overflow <item>Invoke command when dump is finished (-F) <item>Read the list of file to be restored (-X) <item>Support GNU readline on interactive restore </itemize> <!--O などです (2000/07/05 現在)。 --> <p> <!--O なお、dump-0.4 のβバージョンのうち、 0.4b14 以前のバージョンにはセキュリティホールが発見されています。 必ず 0.4b16 以降をインストールしてください。 --> It is known that the dump-0.4b series before 0.4b15 have a security hole. Please make sure to install 0.4b16 or later. <!-- またコマンドラインオプションの仕様に一部変更も加えられていますので、 マニュアルページを確認して使用してください。--> <!-- 現状では dump-0.3 が stable なバージョンであり、 この文書もそれを使用すること を前提に解説することにします。 --> <!--O <sect1>デバイスファイル --> <sect1>Device files <p> <!--O Linux では、テープドライブを使うためのデバイスドライバが標準で提供されていま す。お使いのドライブにあったドライバをカーネルのコンパイル時に組み込んでくだ さい。ローダブルモジュールの形式でもかまいません。 --> Linux natively provides the device drivers for tape drives. Please compile the driver suitable for your drive on the kernel build. Loadable module should also work fine. <p> <!--O 次に、テープドライブのデバイスファイルを確認します。 --> Then, check the device files. <tscreen><verb> % ls -l /dev/*st[0-9] crw-rw-rw- 1 root disk 9, 128 Oct 5 1995 /dev/nst0 crw-rw---- 1 root disk 9, 129 Oct 5 1995 /dev/nst1 crw-rw-rw- 1 root disk 9, 0 Oct 5 1995 /dev/st0 crw-rw---- 1 root disk 9, 1 Oct 5 1995 /dev/st1 </verb></tscreen> <!--O <tt>/dev/nst?</tt> と <tt>/dev/st?</tt> の二種類があります。 (もしなければ、MAKEDEV コマンドで 作成してください。) このうち、st? はコマンドがドライブに対して発行されたあと に、自動的に先頭まで巻き戻し(rewind)するデバイスであり、nst? は巻き戻ししな い(no rewind)デバイスです。このあたりには好みがあるのですが、私は no rewind の方が好きです。今回は <tt>/dev/nst0</tt> をターゲットのデバイスとして 利用することにします。 ターゲットのデバイスが決まったら、そのデバイスファイルから ``<tt>/dev/tape</tt>'' というシンボリックリンクを作成してください。 こうしておくと、mt などのコマンドでデバイス名を省略できます。 --> There should be two kinds of the device files: <tt>/dev/nst?</tt> and <tt>/dev/st?</tt> (if not, make them with MAKEDEV command). st? are ``auto-rewind'' devices, which rewinds the tape after the command is invoked to the driver, and nst? are ``no-rewind'' devices. Which to use is your choice, but I prefer the no rewind ones. In this document, <tt>/dev/nst0</tt> is used for the target device. When the target device is chosen, you may want to creat the symlink to it named ``<tt>/dev/tape</tt>''. With this, you can omit the device name on the command lines of mt and others. <tscreen><verb> % cd /dev; ln -s nst0 tape </verb></tscreen> <p> <!--O もし接続されているテープドライブをバックアップ専用のデバイスと考えるなら、 一般ユーザからのアクセスはすべて拒絶したほうがよいでしょう。 その場合は、`Others' のリード/ライト権限を落としてください。 上記の例では、一台目のテープドライブは一般ユーザのアクセス可、 二台目のテープドライブはバックアップ専用で、所有者とグループ `disk' に 属しているユーザ以外はアクセスが不可になっています。 --> If the tape drive is used for the backup only, you might consider to refuse the accesses to it by normal users. To do this, drop the read/write permissions for `Others'. In the above example, the first tape drive is accessible to normal users, and the second drive is backup purposes only, to which the access is prohibited except for the owner and the users belong to the `disk' group. <sect>mt コマンド <sect1>mt <p> `mt' は、テープドライブを操作するためのコマンドです。テープの巻き戻し・巻き 送り・頭出しや、ドライブの稼働状況の確認などができます。dump/restore をテー プドライブで使うには、mt での操作は避けて通ることができません。できれば、 練習用の短いテープを用意して、慣れるまでいろいろと試すのもいいでしょう。 `mt' にはドライブに依存する機能もあります。必ず一度マニュアルに目を通して、 あなたがお使いのドライブではどのコマンドが使えるのか把握するようにしてくださ い。 <p> Linux で使える mt としては、BSD のものを ベースに Kai Makisara 氏 (<tt/ が 移植した mt-st が一般的です。 ソースパッケージは: <quote> <tt> <htmlurl url="" name=""> </tt> </quote> から入手できます。 <p> もし Archive Python 28849 SCSI ドライブのような DDS Autoloader を 利用する場合は Leonard N. Zubkoff 氏 (<tt/ が 作成・配布している MTX も役に立つでしょう。これは: <quote> <tt> <htmlurl url="" name=""> </tt> </quote> から入手できます。 MTX の使い方に関しては <ref id="mtx-exec" name="このセクションの最後">で解説します。 <sect1>mt の操作例 <p> この章では、実際の mt の操作例を通して、mt の機能について解説していきます。 <p> ドライブにテープ(できれば、練習用のもの)を装填してください。装填が完了したら、 mt コマンドでドライブのステータスを確認してみましょう。mt のオプションコマン ド `status' は、ドライブのステータスを確認するコマンドです。 <tscreen><verb> % mt status SCSI 1 tape drive: File number=0, block number=0. Tape block size 1024 bytes. Density code 0x0 (default). Soft error count since last status=0 General status bits on (41010000): BOT ONLINE IM_REP_EN </verb></tscreen> <p> まず、メッセージの最終行を見てください。ドライブにテープが装填され、最終行の BOT (Beginning Of Tape Marker) 表示によってのヘッドの位置はテープの先頭にあ ることがわかります。次の ONLINE は、テープドライブがオペレータによって操作可 能な状態であることを意味しています。テープを読み書きするには ONLINE の状態で ある必要があります。現在のファイル番号は 0 になっています。ファイル番号はテー プの先頭から 0 で始まり、ファイル終端マーク(EOF)があるごとに、数字が増えます。 <#if output="html"> <figure> <ph vspace="0"> <img src="./dump-restore-mini-HOWTO-images/fig1.gif"> </figure> </#if> <#unless output="html"> <p> (以後の説明、プレインテキスト版ではいくつかの図が使われています。可能であれば 等幅のフォントで閲覧してください) <tscreen><verb> V (<--- Tape Head) /==================================================================/ | B<--- BOT Mark) -> Tape End / \================================================================/ V: Tape Head B: BOT Mark E: EOF Mark </verb></tscreen> </#if> <p> 通常、Density や Tape block size は Drive にあわせて最適なものが 自動的にセットされるはずです。 もし、他の OS とテープをやりとりする 予定がある場合は、両方の OS 間で互換性のある形式を選択する必要が あるでしょう。 また、データをハードウェアで圧縮してメディアに記録するドライブの場合、 mt のコマンドで明示的に compression フラグを与えてやる必要があります。 このあたりはドライブの種類や環境によって異なることが多いので、 解説は省略します。くわしくは mt(1) マニュアルページの defsetblk, setblk, defcompression, datcompression, compresson などの項目と、 お使いのドライブのマニュアルを参照してください。 <p> もし、mt status の結果、次のようなメッセージが出た場合は、 /dev/tape のリンクが指しているデバイスファイルがドライブの つながってるものと異なっている可能性があります。 <tscreen><verb> /dev/nst0: No such device or address </verb></tscreen> その場合は、別のデバイスファイルを -f コマンドで指定して試してみてください。 正常なメッセイジが表示されたなら、リンクをはり直しておいてください。 <p> では、実際に幾つかのファイルをテープに書いて、練習してみることにしましょう。 どこか適当な場所に練習用のディレクトリを作成し、その中にfile-01 から file-06 までのダミーファイルを touch コマンドで作成してください。 <tscreen><verb> (tcsh)% foreach num (01 02 03 04 05 06) foreach? touch file-$num foreach? end (tcsh)% ls -l -rw-r--r-- 1 fuku users 0 Nov 21 01:10 file-01 -rw-r--r-- 1 fuku users 0 Nov 21 01:10 file-02 -rw-r--r-- 1 fuku users 0 Nov 21 01:10 file-03 -rw-r--r-- 1 fuku users 0 Nov 21 01:10 file-04 -rw-r--r-- 1 fuku users 0 Nov 21 01:10 file-05 -rw-r--r-- 1 fuku users 0 Nov 21 01:10 file-06 </verb></tscreen> このファイルを一つづつ、tar でテープに書き込んでみます。 <tscreen><verb> % tar cf /dev/tape file-01 </verb></tscreen> エラーがなにもなければ、うまくいっています。念のために mt のステータスを 確認してみましょう。 <tscreen><verb> % mt status SCSI 1 tape drive: File number=1, block number=0. Tape block size 1024 bytes. Density code 0x0 (default). Soft error count since last status=0 General status bits on (81010000): EOF ONLINE IM_REP_EN </verb></tscreen> 大丈夫ですね。EOF がひとつ追加されたので、ファイル番号が一つインクリメントさ れて、1 になっています。 <tt>/dev/tape</tt> は <tt>/dev/nst0</tt> つまり no rewind のデバイスに 書き込んだので、テープヘッドは今書いたファイルの終端 (EOF) にあります。すでに 次のファイルを書く準備が完了しているということです。 <#if output="html"> <figure> <ph vspace="0"> <img src="./dump-restore-mini-HOWTO-images/fig2.gif"> </figure> </#if> <#unless output="html"> <tscreen><verb> V /==================================================================/ | B[file-01]E / \================================================================/ V: Tape Head B: BOT Mark E: EOF Mark </verb></tscreen> </#if> <p> では、残りのファイルは連続して書いてしまいましょう。 <tscreen><verb> (tcsh)% foreach num (02 03 04 05 06) foreach? tar cf /dev/tape file-$num foreach? end </verb></tscreen> ステータスを確認します。 <tscreen><verb> % mt status SCSI 1 tape drive: File number=6, block number=0. Tape block size 1024 bytes. Density code 0x0 (default). Soft error count since last status=0 General status bits on (81010000): EOF ONLINE IM_REP_EN </verb></tscreen> ファイルはきちんと書き込まれています。テープヘッドは今書いたファイルの終端 にあります。この様子を図にしてみましょう。 <#if output="html"> <figure> <ph vspace="0"> <img src="./dump-restore-mini-HOWTO-images/fig3.gif"> </figure> </#if> <#unless output="html"> <tscreen><verb> V /==================================================================/ | B[file-01]E[file-02]E[file-03]E[file-04]E[file-05]E[file-06]E / \================================================================/ V: Tape Head B: BOT Mark E: EOF Mark </verb></tscreen> </#if> <p> ここで大切なことは、各ファイルには ファイルの中身・ファイルの終端マークのふ たつがあるということです。これは、ファイルが正常にテープに格納されると、自動 的にそのようになります。ファイルを読み出すときは、前のファイルの終端マークに テープヘッドを位置させることによって、ファイルの先頭ブロックから読み出せるこ とになります。また、ファイルを追加して書き込むときは、前のファイルの終端マー クにヘッドが達していなければなりません。言い換えれば、複数のファイルが連続し て記録されているとき、前のファイルの終端マークは、次のファイルの先頭ブロック の開始位置といえます。当然ですが、もしファイルの中身の部分から書き込み始める と、元のファイルの中身は失われてしまいます。 <p> それでは、複数のファイルが順に記録されたテープから、特定のファイルだけを取り 出す方法を練習しましょう。例として、今記録したテープから、file-03 がアーカイ ブされた部分を取り出すことを考えてみます。目的のファイルが記録された位置にヘッ ドを移動することが必要になります。 <p> まず、いったん先頭に巻き戻してから、file-03 がアーカイヴされた位置にヘッドを 移動しましょう。 <tscreen><verb> % mt rewind </verb></tscreen> <#if output="html"> <figure> <ph vspace="0"> <img src="./dump-restore-mini-HOWTO-images/fig4.gif"> </figure> </#if> <#unless output="html"> <tscreen><verb> V /==================================================================/ | B[file-01]E[file-02]E[file-03]E[file-04]E[file-05]E[file-06]E / \================================================================/ V: Tape Head B: BOT Mark E: EOF Mark </verb></tscreen> </#if> <p> file-03 が記録されている部分はテープの中の、ファイル番号 2 の位置です。現在 ヘッドは BOT (テープの頭)にありますから、ここに移動するためには、EOF (ファイ ル終端マーク) をふたつスキップすることになります。 <tscreen><verb> % mt fsf 2 </verb></tscreen> mt のオプションコマンド fsf は、指定個数の EOF をスキップして次のファイルの 先頭ブロックにヘッドを移動するコマンドです。fsf 2 では、 現在の位置から 2 つ先のファイル開始位置にヘッドを移動する ことを意味しています。 <tscreen><verb> % mt fsf 2 </verb></tscreen> <#if output="html"> <figure> <ph vspace="0"> <img src="./dump-restore-mini-HOWTO-images/fig5.gif"> </figure> </#if> <#unless output="html"> <tscreen><verb> V /==================================================================/ | B[file-01]E[file-02]E[file-03]E[file-04]E[file-05]E[file-06]E / \================================================================/ V: Tape Head B: BOT Mark E: EOF Mark </verb></tscreen> </#if> <tscreen><verb> % mt status SCSI 1 tape drive: File number=2, block number=0. Tape block size 1024 bytes. Density code 0x0 (default). Soft error count since last status=0 General status bits on (81010000): EOF ONLINE IM_REP_EN </verb></tscreen> ここでステータスが意味しているものは「ファイル番号 2 (すなわち、ここでは file-02 がアーカイヴされている部分) の終端マーク」であり、言い換えれば 「ファイル番号 3 の先頭ブロック開始位置」を意味しています。tar で中身を 見てみましょう。 <tscreen><verb> % tar tf /dev/nst0 file-03 </verb></tscreen> 意図した通りに、file-03 のアーカイヴがありました。 ステータスを表示させてみます。 <tscreen><verb> % mt status SCSI 1 tape drive: File number=2, block number=10. Tape block size 1024 bytes. Density code 0x0 (default). Soft error count since last status=0 General status bits on (1010000): ONLINE IM_REP_EN </verb></tscreen> ここではステータスに EOF が表示されていないことに注意してください。tar でふ つうにアーカイヴを読み出すと、tar は自身の End of file マークを検知して、そ こで読出しを停止します。これはテープに記録されている EOF とはまた別のものです。 <#if output="html"> <figure> <ph vspace="0"> <img src="./dump-restore-mini-HOWTO-images/fig6.gif"> </figure> </#if> <#unless output="html"> <tscreen><verb> V /==================================================================/ | B[file-01]E[file-02]E[file-03 F]E[file-04]E[file-05]E[file-06]E / \================================================================/ V: Tape Head B: BOT Mark E: EOF Mark </verb></tscreen> </#if> <p> 図の F (画像では青印) が、tar の End of file マークです。 したがって、tar で読出した直後は、 まだヘッドは記録されたブロックの中にあります。このまま次のアーカイヴを 連続して tar で読出そうとすると、今度はテープに記録された EOF マークをすぐに 読み込むことになり、tar は無言のままに終了することになります。もし連続して tar で読出す場合は、その前に <tscreen><verb> % mt fsf </verb></tscreen> として、EOF マークをひとつ読み飛ばせはいいのです。ちょっと間違いやすいところ なので、覚えておいてください。 <p> さて、現在は mt fsf で file-03 がアーカイヴされたブロックの EOF マークにヘッ ドがあるとします。このアーカイヴをもう一度読出したいときはどうすればいいでしょ うか。巻き戻しながら二つ目の EOF マークを読み込んだとき、このファイルの先頭 になるのです。 <#if output="html"> <figure> <ph vspace="0"> <img src="./dump-restore-mini-HOWTO-images/fig7.gif"> </figure> </#if> <#unless output="html"> <tscreen><verb> V <====== V /==================================================================/ | B[file-01]E[file-02]E[file-03]E[file-04]E[file-05]E[file-06]E / \================================================================/ V: Tape Head B: BOT Mark E: EOF Mark </verb></tscreen> </#if> <p> このためには、以下のようにします。 <tscreen><verb> % mt bsfm 2 </verb></tscreen> これは mt の拡張されたコマンドで、ふるい mt にはないものもあります。 その場合は bsf と fsf を組み合わせて処理することになるのですが、 紛らわしいのでここでは省略します。 <p> 次に、現在記録されているファイルに追加して記録するときの操作を説明します。mt eod で、現在記録されているブロックの最後の EOF にヘッドが移動します。ただし、 この機能はドライブによってはうまくいかないこともあるので、実際にためして確認 しておく必要があります。もし、うまくいかなくてもきちんとオペレーションの記録 がとってあれば fsf などで処理できます。 <p> 最後に、テープを巻き戻して排出させましょう。これもドライブの種類に依存することが多いのですが、大抵の場合は <tscreen><verb> % mt offline </verb></tscreen> これで(必要なら)自動的に巻きもどされ、ドライブからテープが Eject されます。 <p> mt をつかったテープのオペレーションはやや難しく、慣れが必要です。 また、<ref id="logging" name="dump の記録">で後述しますが、 記録の状態を確認するのが難しいので、実行したオペレーションの内容の記録を保存することが大切です。 ぜひ練習用のテープを用意して、いろいろとためしてみてください。 <sect1>MTX の操作例(集合型テープドライブの操作)<label id="mtx-exec"> <p> 複数のテープを連装できるタイプのテープデバイスがあります。 Archive Python 28849-XXX や、HP Surestore 12000, Quantum DLT 2500 XT といった集合型のドライブです。 たいていの場合、複数のテープを専用のカートリッジ・マガジンに装填し、 それをドライブ本体に挿入します。 その後、カートリッジ・マガジンに装填されたテープのうち、 任意の物をローディングすることによって、 実際に読み書きできるようになります。 <p> このメディアチェンジの作業はドライブ本体に専用のスイッチがあって、 それを手動で操作できる場合もありますが、 実際にローディングされたテープが目的のものかどうか確認することが 困難であったり、カートリッジ・マガジンに装填されたテープの 順番通りにしかメディアチェンジできなかったりする場合もあり、 使い勝手があまりよくないこともしばしばあります。 <p> これはこの章の最初に述べたように、 Leonard N. Zubkoff 氏 (<tt/ が作成・配布している MTX を利用することによって、簡単に解決することができます。 MTX は mtx という単独のプログラムです。 現在配布されているバージョンは 1.1 で、 Debian GNU/Linux (potato) ではバイナリも用意されています。 <p> バイナリが入手できない場合でも、 kernel 2.0.30 以降であれば簡単にコンパイルすることができます (これより古いバージョンのカーネルで利用する場合は、 MTX の配布アーカイブに含まれている mtx.doc の ``LINUX KERNEL REQUIREMENTS'' の章を参考にヘッダファイルに小さな変更を加えれば OK です)。 また、コンパイルの際には kernel のソースツリーが必要です。 kernel のソースツリーの状態によっては 「ヘッダファイルが見つからない」 というエラーでコンパイルに失敗することがありますが、その場合は Makefile の CFLAGS の行に -I/usr/src/linux/include を付加してください。 <verb> CFLAGS = -O6 -m486 -fomit-frame-pointer -I/usr/src/linux/include </verb> <p> では、実際に MTX を使って集合型テープドライブを操作してみましょう。 すでにカートリッジ・マガジンにはテープが装填されており、 マガジンがドライブ本体に挿入されているものとします。 <p> この状態では、まだどのテープもマガジンに装填された状態のままで、 テープへッダのある位置にロードされていません。 ためしに mt で確認すると、``テープが挿入されていない'' というステータスが帰ってきます。 mtx にもこのステータスを表示する機能があります。 使い方は mt とまったく同じで、 デバイス名とオプショナルコマンド ``status'' を付加するだけです。 <tscreen><verb> # mtx -f /dev/nst1 status Data Transfer Element: Empty Storage Element 1: Full Storage Element 2: Full Storage Element 3: Full Storage Element 4: Full Storage Element 5: Full Storage Element 6: Full </verb></tscreen> ``Data Transfer Element'' というのが実際に読み書きを行う装置で、 現在は空 (Empty) になっています。 ``Storage Element 1-6'' は、カートリッジ・マガジンの状態を示しています。 各番号はマガジン内での装填順で、これをストレージ番号と呼びます。 現在は六つのすべてのマガジンに テープが装填された状態 (Full) であることを示しています。 <p> では、``Data Transfer Element'' にテープをロードしてみましょう。 この操作も mtx でおこないます。オプショナルコマンド ``load'' に、 ストレージ番号を付加するだけです。 <tscreen><verb> # mtx -f /dev/nst1 load 1 Loading Storage Element 1 into Data Transfer Element...done </verb></tscreen> これで一番目のテープがロードされました。status コマンドで確認してみましょう。 <tscreen><verb> # mtx -f /dev/nst1 status Data Transfer Element: Full (Storage Element 1 Loaded) Storage Element 1: Empty Storage Element 2: Full Storage Element 3: Full Storage Element 4: Full Storage Element 5: Full Storage Element 6: Full </verb></tscreen> ``Data Transfer Element'' にストレージ番号 1 のテープがロードされたことが わかります。同時に、マガジン内のストレージ番号 1 の位置は空になっていることも 確認できます。 <p> この状態になれば、 あとは通常のドライブと同様に mt を使って テープの操作ができるようになっています。 それでは、ロードされたテープをマガジンに戻すにはどうするでしょう。 これはオプショナルコマンド ``unload'' を使うだけです。 <tscreen><verb> # mtx -f /dev/nst1 unload 1 Unloading Data Transfer Element into Storage Element 1...done </verb></tscreen> <p> テープのロードは、任意のストレージ番号に対して行えます。 では、ストレージ番号 2 のテープをロードしてみます。 <tscreen><verb> # mtx -f /dev/nst1 load 2 Loading Storage Element 2 into Data Transfer Element...done </verb></tscreen> うまくいきました。 この状態で、別のストレージ番号を指定してロードすると、先にロードされていた テープは自動的に unload され、指定されたテープが代わりにロードされます。 マガジン内のストレージは、番号だけでなく「次のテープ」「前のテープ」 といった指定方法も可能です。先ほどのテープ 2 がロードされた状態で、 オプショナルコマンド ``next'' を発行してみましょう。 <tscreen><verb> # mtx -f /dev/nst1 next Unloading Data Transfer Element into Storage Element 2...done Loading Storage Element 3 into Data Transfer Element...done </verb></tscreen> ストレージ番号 2 のテープが unload され、 代わりにストレージ番号 3 のテープがロードされました。 ここから、もう一度前のテープに戻るには オプショナルコマンド ``previous'' を 使います。 <tscreen><verb> # mtx -f /dev/nst1 previous Unloading Data Transfer Element into Storage Element 3...done Loading Storage Element 2 into Data Transfer Element...done </verb></tscreen> 先ほどの状態に戻ったことがわかります。 <p> この他にも ``first (マガジンにある最初のストレージ番号のテープをロードする'' ``last (マガジンにある最後のストレージ番号のテープをロードする)'' などのオプショナルコマンドがあります。 なお、これらのコマンドは、dump-0.4b17 以降であれば、 実際の dump の途中でテープエンドに達したときを見計らって 実行することができます。膨大なディスクを一度にバックアップするときには 大変便利な機能です。 <sect>dump を使ったバックアップ <sect1>バックアップするファイルシステムの選択 <p> それでは、dump を使っての具体的なバックアップ作業について、順に解説してい きます。 <p> バックアップは「すべてのファイルシステム」に対して行うことが原則です。 <p> ただし、フルレストアする時に、復元される必要のないファイルシステムまで、dump する必要はありません。<tt>/tmp</tt> が独立したファイルシステムなら、 これは真っ先に除外することができます。 これに類する物としては、proxy デーモンなどのキャッシュ ファイルもそうでしょう。また、Netnews の spool や、overview database, history などは、きっぱりあきらめてしまえば、これも除外することがで きます。 <p> これらを除いて、全てのファイルシステムを対象にします。対象となるファイルシス テムは、<tt>/etc/fstab</tt> の第5フィールドで 1 のフラグを立てておきます。 以下は、その例です。 <code> # /etc/fstab # /dev/hda2 / ext2 defaults,noquota 1 1 /proc /proc proc defaults,noquota 0 0 /dev/sdb3 /tmp ext2 defaults,noquota 0 2 /dev/sdb2 /var ext2 defaults,noquota 1 3 /dev/sdd2 /usr ext2 defaults,noquota 1 2 /dev/sdd1 /usr/local ext2 defaults,noquota 1 3 /dev/sde1 /var/spool/news ext2 defaults,noquota 0 4 /dev/sdc1 /var/spool/ov ext2 defaults,noquota 0 3 /dev/hda3 /.d1 ext2 defaults,noquota 1 2 /dev/hdb1 /.d2 ext2 defaults,usrquota 1 4 /dev/sdb1 /.d3 ext2 defaults,ro,noquota 1 4 /dev/sda5 /home ext2 defaults,usrquota 1 3 /dev/fd0 /mnt/floppy ext2 defaults,noauto,noquota 0 0 /dev/sdb4 none swap sw 0 0 </code> この例では、<tt>/tmp</tt>, <tt>/var/spool/news</tt> に加えて <tt>/proc</tt> そして <tt>swap</tt> の第 5 フィール ドも 0 になっています。よく、これらが 1 になっている人を見掛けますが、まった く意味がありませんし、誰かに見られると恥ずかしいので、ついでに直しておきましょ う。 <sect2>バックアップしないファイルを除外する<label id="exclude"> <p> ディスクの区画分けの状態によっては、バックアップするファイルシステムの 中に、バックアップしたくないファイル群が含まれてしまうことがあります。 どうしてもそれらを除外したい場合は、専用のツールを使ってファイルが使用する i-node に除外の目印 (no dump flag) をつけることができます。 Proxy キャッシュディレクトリのように、頻繁に更新されるがバックアップの意味が ないファイル群に対して、この attribute を設定するとよいでしょう。 <p> くわしい使い方は lsattr(1) と chattr(1) を参照して欲しいのですが、 <tscreen><verb> # lsattr -d /var/spool/squid ------- /var/spool/squid # chattr +d /var/spool/squid # lsattr -d /var/spool/squid ------d /var/spool/squid </verb></tscreen> というふうに、chattr コマンドで +d の no dump flag をつけたものは、dump の対 象から外せます。上の例では、Squid cache system が使用するキャッシュディレク トリとその巨大な中身に対して、そのような目印をつけています。ディレクトリに対 してこの目印がつくと、その後は中に作成されるファイルも同じ属性になります。 <p> ただし level 0 のフルダンプの際デフォルトではこの指定は無視され、実際に効果 があるのは level 1 以降のインクリメンタルバックアップの時になります。 もし level 0 の時も同じ効果を得たい場合は dump の h オプションで指定する必要 があります。 <sect1>フルバックアップ <sect2>ファイルシステムを静止する <p> では、いよいよフルバックアップを行います。 <p> フルバックアップの前には、システムをシングルユーザモードに移行し、各ファイル システムを静的な状態にして fsck をかけて、ファイルシステムに矛盾が生じていな いことを確認したほうがよいでしょう。フルバックアップはめったに行うものではあり ませんから、面倒でもやっておくことをお勧めします。 <tscreen><verb> # init 1; exit </verb></tscreen> まず、これでシングルユーザモードになります。 <p> 次に、ファイルシステムをひとつず つアンマウントし、ファイルシステムのチェックを行います。 <tscreen><verb> # umount /usr/local; e2fsck -afv /dev/sdd1 </verb></tscreen> (いちいちアンマウントするのが面倒であれば、 システムが起動するときに、あらかじめ Boot prompt で ``<tt>linux -b</tt>'' を指定して、ルートファイルシステムだけをマウントした状態に する方法もあります。) <p> チェックはバックアップの対象となっている 全てのファイルシステムに対して行います。 ルートファイルシステムだけは注意が必要で、 一旦リードオンリーでマウントし直し、e2fsck をかけます。 <tscreen><verb> # mount -r -n -o remount / ; e2fsck -afv /dev/hda3 </verb></tscreen> すべてのチェックが完了したら、 <tscreen><verb> # mount -w -n -o remount / </verb></tscreen> として、ふたたびリードライトでルートファイルシステムをマウントします。 (リードオンリーのままだと、dump がバックアップ情報を残すことができません。) ネットワーク越しに dump をする場合など、<tt>/usr</tt> ファイルシステムが必要な 場合は、それらのファイルシステムを再度マウントし、ネットワークが 利用可能な状態にします。 <sect2>ドライブの準備<label id="drive_junbi"> <p> 次に、バックアップメディアの準備をします。ここでは EXABYTE のEXB-8200 ドライ ブ (SCSI) に、112m の 8mm データカートリッジを使うことを例にします。 <p> 最初に行うことは、テープヘッドのクリーニングです。EXABYTE の場合は、クリーニン グテープを装填すると、自動的にロードされてヘッドのクリーニングを行い、最後に 巻き戻さずに Eject します。この作業は、とくに level 0 の dump を行う際には必 ず実行する癖をつけてください。テープの読み書きの際にエラーが起きる可能性を確 実に減少してくれます。 <p> それからドライブに新品のテープを装填します。テープにはあらかじめラベルを貼っ ておきましょう。これをサボると、あとでだんだんわけがわからなくなりますよ。ラ ベルの内容は、これまでに購入したテープの通し番号で充分です。後述しますが、ラ ベルにあれこれ書くよりも、別に専用の管理ノートを用意して、細かなメモはそちら に記録することをおすすめします。テープをドライブに装填し終えたら、mt コマン ドでステータスを確認します。 <tscreen><verb> # mt status SCSI 1 tape drive: : : </verb></tscreen> このコマンドの出力は、ドライブの種類によって異なります。ここでは、テープがロー ドされていることが確認できれば充分です。 <sect2>dump する <p> さて、いよいよ dump です。使い方はそれほど複雑ではありませんが、パラメータの 指定の仕方にちょっと癖があります。(v0.3 より新しいバージョンでは柔軟な指定も 可能になっていますが、ここでは古典的な文法に従います) <code> 使用方法: dump `オプション' `パラメータ' `ファイルシステム' - オプション: 0123456789BbhfusTdWn 0 〜 9 : dump level B : ボリュームあたりのレコード数 b : 1 レコードのブロックサイズ(KB) h : nodump アトリビュートが影響する dump level f : 出力先ファイル(テープ)の指定 d : 記録密度 n : オペレータに注意を促す s : テープの長さ u : /etc/dumpdates を更新する T : /etc/dumpdates に記録する日時を指定する W : dump の対象になっているファイルシステムに 印をつけて表示する w : dump が必要なファイルシステムだけを表示する - パラメータ オプションの順に対応したパラメータを指定する。 たとえば、``sbf'' の順にオプションを並べた場合は、 dump sbf `テープの長さ' `ブロックサイズ' `出力先' `ファイルシステム' という順になる。 - ファイルシステム dump するファイルシステムのマウントポイントまたはデバイス名 </code> 典型的なコマンドは以下のようなものです: <tscreen><verb> # dump 0uf /dev/nst0 /home </verb></tscreen> <p> 最初の引数の数字は、0-9 の Dump level です。詳しくは後述しますが、`0' がフル バックアップを意味していると思ってください。`u' は、次回のインクリメンタルバッ クアップに備えて <tt>/etc/dumpdates</tt> を更新することを指示するものです。 <tt>/etc/dumpdates</tt> には、dump した時刻やレベルが記録されます。この情報は その後 dump プログラムによってインクリメンタルバックアップの際や w, W オプションで参照されます。 <p> テープに dump する場合は blocksize や tape length を指示する必要があるでしょ う。もし「テープの容量は充分なはずなのに、途中で tape end に達してしまう」場 合は、このあたりに工夫が必要です。いい加減なやりかたですが、B option で、容 量を多めに明示してしまう方法もあります。 <tscreen><verb> # dump 0uBf 2300000 /dev/nst0 /home </verb></tscreen> ここでは、8mm テープの容量におよそ 2.3GB という多めの見当 (blocksize で 2.3GB を割った数値を) を dump に指示しています。density や tape length の指 示はメディアの終了を検出できないドライブを使う場合に dump にメディア交換のタ イミングを教えてやるためのオプションです。しかし、最近のほとんどのドライブは テープエンドをきちんと検出できるので、このような方法でも問題がないでしょう。 <p> 正常に dump がスタートすれば、いくつかのメッセージとともにバックアップは進行 します。このとき、バックアップ終了までにかかるおおよその時間などが表示されま す。このジョブは、最初のころはバックグラウンドに回さずに、 フォアグラウンドで実行してください。 もしテープエンドに達したり、なんらかのエラーが発生した場合は、 対話的な選択処理を求められることがあるからです。 <p> dump が無事に終了し、まだテープ残量に余裕がある場合は、そのまま続けて別のファ イルシステムの dump を行うことができます。 <sect1>ダンプレベルとインクリメンタルバックアップ <p> dump はダンプレベルを指定されることによって、バックアップの動作を決定します。 ダンプレベルは 0-9 の範囲の整数で、指定がない場合は 1 が指定されてた物と仮定 されます。あるダンプレベルが指定されると、それより小さい数のダンプレベルで dump が実行された時刻より後に更新されたファイルだけをバックアップの対象にし ます。 <p> たとえば、level-4 のバックアップの後、level-5 のバックアップが実行されると、 level-4 バックアップ以降に更新されたファイルが level-5 のバックアップアーカ イブに記録されることになります。 <p> この仕組みを利用すると、インクリメンタルバックアップが簡単にできることになり ます。たとえば、 <code> 1 日目 level 0 2 日目 level 1 3 日目 level 2 4 日目 level 3 5 日目 level 4 6 日目 level 5 7 日目 level 6 8 日目 level 7 9 日目 level 8 </code> という順に dump を実行すると、2 日目以降は前日から更新のあったファイルだけを バックアップします。こうすることによって、バックアップに要する時間を最大限に 節約することができます。 <p> もうちょっと凝った方法としては、``ハノイの塔のシーケンス'' という方法で dump level のスケジュールを組むというやり方があります。 <p> たとえば: <code> 0 -> 3 -> 2 -> 5 -> 4 -> 7 -> 6 -> 9 -> 8 -> 1(a) -> 3 -> 2 -> 5 -> 4 -> 7 -> 6 -> 9 -> 8 -> 1(b) -> 3 -> 2 -> 5 -> 4 -> 7 -> 6 -> 9 -> 8 -> 0 に戻る </code> という順に dump を進めます。level 0 のテープは安全な場所に永久保管し、level 0 dump では常に新しいテープを使うようにします。 level 1 のテープはローテーション分 (上の図の例では 2セット) 用意します。 それ以外のテープは 1 set ずつで充分です。 <p> この方法のメリットは、ある時点でのファイルシステムの状態を長い時間保存でき、 かつバックアップの時間とメディアを節約できることです。 <p> ところで level 0 のフルバックアップの際にはシングルユーザモードで作業をしま した。では、level 1 以降のインクリメンタルバックアップの際にはどうすべきでしょ うか。日常的にバックアップをするようになると、いちいちシステムの運用を停めて いられない、というのが実情でしょう。私はマルチユーザモードでやっても構わない と思ってます。このあたりは運用の利便をとるか、安全を取るかの選択になります。 <p> ただし、そのインクリメンタルバックアップの直後に クリティカルなハードウェアなどのメンテナンスが 予定されているようなケースでは、 システム停止直前の状態を確実に保存するために、 level 1 のインクリメンタルバックアップを シングルユーザモードで行うほうがよいでしょう。 <sect1>dump の記録<label id="logging"> <p> <ref id="drive_junbi" name="ドライブの準備"> の項で「テープのラベルにあれこれ書くよりも、別に専用の管理ノー トを用意して、細かなメモはそちらに記録するほうがよい」と書きました。 これは、記録しなければならない項目がラベルに収まるほど少なくはないからです。 <p> この記録が必要になるのは restore の時です。どのテープのどの位置に、どのファ イルシステムが記録されているのか、すぐにわかるようにしておくことが重要です。 (そういうときは大抵、軽いパニックになっていたりしますから) <p> ここはひとつ、専用の管理ノートか、プリンタ出力を保存するバインダを用意して、 dump を実行している間に詳細なメモを記録するようにしましょう。記録しておきた いことは: <code> [Tape No.nnnn] テープそのものの通し番号 File count: テープ先頭からの位置 Date: 日付 Host: dump の対象となったホスト名 Filesystem: ファイルシステムの名前 Device: ファイルシステムのデバイス名 Level: dump level Blocks: アーカイヴされたブロック数 Length: テープ中でこのアーカイヴの占める長さ </code> くらいで充分でしょう。たとえば、 <code> [Tape No.0024] Date: Wed Nov 12 12:39:57 1996 File count: 1 Host: nicorn Filesystem: /home Device: /dev/sda5 Level: 0 Blocks: 392556 Length: 0.16 </code> というぐあいです。これは、dump のステートメント出力を perl などで整形すれば 簡単ですから、それほど手間はかかりません。これをプリントアウトして、バインダ に綴じておけばOK です。 <p> バックアップとは直接の関係はありませんが、 ついでに fdisk -l の出力などもプリントアウトしておくと、 事故の際の復旧には参考になるでしょう。 <quote> (FYI: dump 実行の際にログを自動的に保存するようなスクリプトが <newline> <htmlurl url="" name=""> <newline> で公開されています。私はこれに気づく前に自作のものを使い始めて しまったので詳しいことはわかりません。) </quote> <p> もうひとつ余力があればやっておきたいことは、アーカイヴに格納されたファイルの 一覧をテキストファイルに保存しておくことです。 これは dump を行うごとに mt コマンドでテープを巻き戻し、 restore -t を実行してその出力を保存するとよいでしょう。 このファイルを、たとえば <tt>/var/spool/adm/dump_index/</tt> などの ディレクトリ以下に保管しておけば、 部分的な restore の際に、どのアーカイヴに目的のファイルが入っているのか grep コマンドで探し出すことが容易になります。 同時に、restore -t を実行しておくことで、今作成したばかりのアーカイヴが 正しく読み出せるかどうか、確認できることにもなります。 <sect1>rdump <p> rdump を利用してネットワーク越しに dump を実行することもできます。引数などは dump と同じですが、dump 先の指定には、リモートマシン名をつける必要があります。 (実は rdump の実体は dump そのものです)。 以下の例は、ローカルマシンの <tt>/home</tt> をリモートマシン `tapeserver' に接続された テープデバイスに dump することを示しています: <tscreen><verb> # rdump 0uf tapeserver:/dev/nst0 /home </verb></tscreen> <p> ネットワーク越しに dump する際には、 rsh がパスワードなしに実行できる環境になっている必要があります。 さらに、dump はリモートマシン上で <tt>rmt</tt> を起動しますので、 <tt>rmt</tt> が rsh 環境での実行ファイル検索パスに含まれている ことも条件になります。Linux のディストリビューションによっては、 <tt>rmt</tt> が実行ファイル検索パスに置かれていないことがあります。 <code> # rsh remotehost which rmt </code> の結果、<tt>rmt</tt> が見つからなかった場合は、シンボリックリンクを 作成して <tt>rmt</tt> が rsh 環境での実行ファイル検索パスに含まれる ようにしてください。 <p> また、通常バックアップの作業は root で行うことになりますが、 root がパスワードなしにリモートシェルを実行できる環境は セキュリティを考えると問題があります。 <p> 多少なりとも危険を回避するためには、dump 専用の uid を用意した方が よいでしょう。手順は以下の通りです。 <itemize> <item> LAN 内のすべてのホストに vipw でユーザ名 fsdump を追加する。 パスワードは ``<tt>*</tt>'' でよい。 <item> ユーザ名 fsdump のホームディレクトリを <tt>/etc/fsdump</tt> にする。 <item> ホストの OS が Linux の場合はユーザ名 fsdump を disk グループに追加する。 (その他の OS にも、同等のグループが存在するはずです) <item> テープドライブの接続されたホストの <tt>/etc/fsdump</tt> に <tt>.rhosts</tt>ファイルを作成し、LAN 内のユーザ fsdump がパスワードなしで アクセスできるように記述する。 <item> リモートからの dump は su で fsdump になって作業する。cron から 起動する場合も、fsdump の cron を利用する。 </itemize> <sect1>テープの保管 <p> level 0 のテープはできるだけ長期間保管されることが 望まれます。 いうまでもないことですが、 テープはその性質上、熱やほこり・湿気・磁気に弱いので、 温度変化の激しい場所や直射日光の当る場所などに保管すると、 データが正常に読み出せなくなることがあります。 <p> また、level 0 と 1 のテープはマシンの置いてある部屋以外、 可能であるなら別の建物に保管することが推奨されています。 これは火災などの事故によって、マシンとテープの両方が 一度に失われてしまうことを避けるためです。 <p> 部分的な restore を迅速にサービスしたい場合は、 level 2-9 のテープくらいはマシンと同じ部屋に保管しておきたい場合も あるでしょう。 それでも管理者以外の人間が触れることのできる場所に テープが保管されている状態は、セキュリティ上好ましくありません。 <p> もっとも望ましい状態は耐火・耐熱性の金庫などに入れて施錠することです。 これを大げさと思うならば、せめてテープのラベルには「他人が読んでも 中身がわからない」情報だけを書くようにしましょう。 中身を読み出されてしまえば同じことなのですが、悪意を持った人物の 行為を助けるようなことはしないほうがましです。 <ref id="logging" name="dump の記録">でも触れたように、 別のノートなどに詳細な記録を保管しておけば、混乱の原因にはなりません。 <p> level 0 のテープは定期的にロードしてみて、リードエラーが 起きないことを確認すると安心といわれていますが、ここまでやるのは 本当に大変なので、よほど余力がある場合に限られるでしょう (私はやっていません)。それよりは定期的に level 0 のフルダンプを 新しいテープに行う方が確実です。 <sect1>スケジューリング <p> これでとりあえず手動でバックアップすることができるようになりました。でも、 退屈な作業は長続きしないので、できるだけ作業を自動化することを考えましょう。 同時に、どれくらいの頻度でバックアップをするのか、そのスケジュールも考える 必要もあります。 <p> バックアップの頻度は、システムがどのように利用されているかによって異なります。 また、バックアップ作業をする人がどの程度の労力をかけられるのか、 バックアップアーカイブにはどの程度の完全性が要求されているのか、 その完全性を確保するために犠牲になるものは何か、 どれくらいのコストが必要になるか、 なども考慮に入れて総合的に判断しなければなりません。 <p> 理想的には、マシンを使った日は、かならず一度インクリメンタルバックアップをす るべきですが、個人ベースで利用している場合は、数日の間を開けてもかまわないで しょう。逆に神経質な人は特定のファイルシステムだけは数時間に一度バックアップ したいと考えるかも知れません。 <p> 目安として「一回のインクリメンタルバックアップの全分量が、一本のテープに収ま らないほど間隔をあけないようにする」ことはひとつの条件です。途中で テープのかけ替えが発生しなければ、無人で作業を行える可能性があるからです。 <p> しかし、テープの余裕がありあまるとしても、最低週に一度はバックアップを更新す ることを目安にしてください。データは、新しい物ほど重要であるケースがほとんど で、一カ月前のデータが復元されても、何の役にも立たない場合があります。 <p> また、バックアップを実行する時間も考慮してください。level 0 のフルバックアッ プの際には、システムの運用を停止しなければなりません。それ以外の level のバッ クアップ作業も、できればシステムの負荷が低く、ファイルシステムの更新頻度が 低い時間帯 (深夜など) を選んだ方がよいでしょう。 <p> これらのバランスを考えて、あなたのシステムに最適なスケジューリングを見つけ出 してください。そのスケジューリングに、テープドライブのクリーニング作業を入れ るのを忘れずに。 <!-- 具体例省略 1999.2.1 --> <sect>restore <p> restore(8) は、dump(8) を使って作成されたアーカイヴからファイルを取り出し、 ファイルシステムに復元するためのプログラムです。 ファイルシステム全体の復元を一度に行うこともできますし、 対話的に必要なファイルを選択し、部分的な復元を行うことも可能です。 dump と restore をパイプで組み合わせることによって、 あるファイルシステムの中身を、別のファイルシステムにコピーすることもできます。 rdump と同様、rrestore はリモートホストに接続されたテープドライブの アーカイブを読出すこともできます。 <p> <code> 使用方法: restore `キー' [キー修飾文字] キー (主なもののみ): i 対話的にファイルを取り出す r アーカイヴ全体をカレントディレクトリに取り出す R 中断したフルレストアを再開する t アーカイヴ中のファイルのリストを出力する C 現存するファイルシステムとアーカイヴを比較する T テンポラリディレクトリを指定する s テープの中のアーカイヴの位置を指定する x 指定したファイルだけをアーカイヴから取り出す f アーカイヴファイルを指定する h ディレクトリ名を指定したときに、ディレクトリのみを対象にする v 冗長に実行する y エラーが発生しても問い合わせをしない </code> 典型的な使い方としては: <code> restore rf /dev/nst0 (テープのアーカイヴからカレントディレクトリに ファイルをすべて取り出す) restore isf 3 /dev/nst0 (テープの 3 番目のアーカイヴから対話的にファイルを取り出す) rrestore tf tapeserver:/dev/nst0 (ホスト tapeserver に接続されたテープからアーカイヴの リストを取り出す) </code> などがあります。 <p> 使い方はそれほどむずかしくありませんが、ちょっと特殊なツールなので 一度は操作して慣れておく必要があります。基本的な操作に関する解説は restore(8) マニュアルの繰り返しになるので、ここでは省略します。 <sect1>レストアの際の注意 <p> 対話的にファイルの部分レストアをする際に、 一般的には直接ターゲットとなるディレクトリに上書きするのではなく、 空のディレクトリをカレントディレクトリにしてファイルを書き戻し、 その後しかるべき場所にファイルを移動します。 フルレストアの際には、フォーマットしたディスクをマウントし、 そのマウントポイントに移動してから restore を起動します。 したがって、root パーティションを含めたフルレストアの際には、 非常用のレスキューフロッピーディスクなどが必要となります。 <p> 注意が必要なのは、フルレストアの際にアーカイヴからファイルを取り出す順番です。 特に r コマンドでアーカイヴ全体を展開する場合は、必ず level 0 のアーカイヴ から開始する必要があります。 <p> また、ある dump レベルより後に、それより若い数のレベルで dump が行われた時、 フルレストアの際には無効になる level がでてきます。 たとえば、``ハノイの塔のシーケンス'' にしたがって <code> 0 3 2 5 4 7 6 9 8 </code> と dump を続けたケースでは、level-3 のアーカイヴは、その後に続く level-2 の dump が行われた時に無効になります。同じように、 level-5 のアーカイヴは、その後に続く level-4 の dump が行われた時に、 無効になります。極端にいうと、level-0 の dump が行われれば、 それまでの level-[1-9] のアーカイヴは、すべて無効です。 <p> したがって、フルレストアをする際には、無効になったレベルのバック アップを飛ばして restore を実行することになります。上記のシーケ ンスの場合、 <code> 0 2 4 6 8 </code> と restore していけば、ファイルシステムは最後のバックアップの状 態に戻ります。 <p> これを ``ハノイの塔シーケンス'' にしたがってそのまま restore しよ うとするとどうなるでしょうか。 <p> level-2 のテープを restore しようとすると、``Incremental tape too high'' とエラーが出てしまい、それ以降の restore では ``Incremental tape too low'' といわれます。 <p> これらのエラーが出た場合は、そのまま restore を続けても正常にフ ルレストアできませんから、最初から restore をやり直してください。 <p> (中間で無効になってしまうレベルが生じてしまうからといって ``ハノイ の塔シーケンス'' に意味がないわけではありません。頻繁に更新される ファイルシステムの、過渡的な状態をできるだけ長い期間保持し、なお かつバックアップのメディアを節約するためには、効率のよい方法とい えます。) <p> もうひとつ気をつけなければいけないのは、restore は比較的大きなテンポラリ スペースを必要とするということです。 Rescue Disk などで復旧のために起動したときには、 通常わずかなテンポラリスペースしか用意されていません。 復旧しようとするディスクには、当然 mke2fs で新たにファイルシステムを 作成しますが、作業用テンポラリスペースのためにも、別の 空いているファイルシステムを作成してください。 そして、そのスペースを <tt>/tmp</tt> にマウントするか、restore の T を 使ってテンポラリスペースとして指定するようにしてください。 これはうっかり忘れがちなことなので注意が必要です。 <p> それと、勘違いしてしまう方も多いのですが、 dump/restore はディスクのブートブロックなどは保存/復旧しません。 フルレストアをした後には OS のブートに関わる設定を再確認してください。 <sect1>フルレストアの手順 <p> 以上のことをふまえた上で、トラブルによってフルレストアが必要になったケースの 手順を参考としてまとめておきます。 <p> <itemize> <item> ハードウェアの故障が原因なら、まずその問題を解決する。 <item> dump 状況を記録したノートをよくにらんで、復旧の手順を 紙に書き出して確認する。 <item> テープドライブにセットするテープは、 ノッチが書き込み禁止になっていることを必ず確認する。 <item> レスキューシステムで起動する。 <item> 復旧のターゲットとなるディスクをフォーマットする。 <item> 復旧のターゲットとなるディスクを仮のディレクトリにマウントする。 <item> restore が使用するテンポラリスペースを確保する。 <item> インクリメンタルアーカイヴを順にレストアする際には、 最後のレストアが終了するまで <tt>./restoresymtable</tt> を消さない。 <item> OS のブート手段 (lilo など)を再設定する。 <item> restore がすべて終わり、復旧に成功したことが確認できたら <itemize> <item> <tt>./restoresymtable</tt> を削除する <item> level 0 の dump を新しいテープに行う。 (古いテープも当分の間保存する) </itemize> </itemize> <sect>バックアップは本当に必要か? <p> さて、バックアップは本当に必要なのでしょうか? <p> 「再インストールすれば、それですむ」という考え方もあります。でも日常的に Linux を使っていれば、ファイルシステム上には苦労して作り上げたプログラム、書 きかけのドキュメント、大切な人からもらったラブレターがホームディレクトリのど こかにあります。一度失われてしまったそれらのファイルは、システムを再インストー ルしても、もう戻ってきません。 <p> そして、あなたがシステム自体に手を加えたり (大抵の場合、<tt>/etc</tt> の ファイルの大半には手が入ってます)、 独自にソフトウェアのインストールをしていたりしたら、 被害はさらに拡大します。あなたはシステムを再インストールした後、すべてのコン フィグレーションをやり直し、ソフトウェアを元通りの形で動作するようにコンパイ ル・インストールすることになるでしょう。 <p> ``ext2 ファイルシステムは頑丈なのでめったなことでは壊れない。 したがってバックアップは必要ない'' という意見もあります。確かに ext2 ファイルシステムが破綻をきた すことはほとんどありません。私の経験では、ext2 ファイルシステムがソフトウェ ア上の問題が原因で破壊されてしまったことはありません。 <p> しかし、どんなに注意をはらっても、いつかファイルに関するトラブルに遭遇します。 あるユーザがひとつのファイルを削除してしまうという、軽度のミスもあれば、ハー ドウェアのトラブルが原因でファイルシステムに矛盾を生んでしまうこともあります。 私は SCSI ホストアダプタに異常が生じて機能を停止して しまった経験を持っています。この時は e2fsck では修復できないエラーがディスク に生じてしまい、失われてしまった多数のデータを回復するにはバックアップに頼る 以外ありませんでした。 <p> バックアップの作業は、それ自体がシステムのリソースを必要としますし、なにより 「とっても退屈」な作業です。しかし、これはなにより大切な任意保険と考えてくだ さい。それも、その辺の保険会社がトラブルの時にあれこれ理由をつけて支払いをし ぶるのに比べれば、ずっと正直で確実な保険です。 <appendix><sect>この文書について <sect1>Copyright notice <p> Copyright(c) 1998,1999 by FUKUSHIMA Osamu <p> この文書の著作権(C)は福島於修 <tt/<>/ が 保持します。この著作権表示が全てのコピーに残されるかぎり、 この文書は自由に複製・配布することができます。 部分的に配布する場合には、著作権に関する記述と 完全な文書の在処を併記すると共に、 それが部分的な配布であることを明記されるようお願いします。 なお、これらの複製・配布にあたっては、著作権保持者の許可は必要ありません。 <sect1>責任の放棄 <p> この文書の内容は無保証であり、私は本文書の内容についての責任を否認します。 本文書に含まれている例などを使用するのは、全て読者の責任で行ってください。 <sect1>謝辞 <p> 集合型テープドライブの章を執筆するにあたり、 NEC (NECソリューションズ) 様 から検証用機材をお借りしました。ありがとうございました。 <sect1>フィードバック <p> 質問・コメント・訂正などこの文書に関するご意見は: <verb> FUKUSHIMA Osamu <> </verb> までお願いします。 <sect1>履歴 <p> <verb> 1998年 4月20日 初版発行 (Revision 1.3) 1998年 6月 3日 デバイスファイルの permission に関する記述を追加。 Leonard N. Zubkoff 氏 ( が作成・配布 している MTX に関する記述を追加。 1998年11月15日 テープドライブ全般に関する情報へのポインタを追加。 1998年12月12日 dump-0.3 が kernel 2.0.x で使えることを明記。 1999年 2月28日 e2compr 使用時の制限に関する記述を追加。 1999年 3月10日 第2版発行 (Revision 1.4) 1999年 5月23日 rmt が実行PATHに含まれていない場合に関する記述を追加。 1999年 7月30日 restore の際の注意点を追加。 1999年11月30日 Stelian Pop 氏による新しい 0.4 beta シリーズに関して記載。 2000年 1月21日 0.4 beta 公開サイト名の変更。 2000年 8月 1日 MTX に関する章を追加. </verb> </article>