いますぐ実践! Linuxシステム管理

[バックナンバーのトップへ] [Linux システム管理のトップへ]


いますぐ実践! Linux システム管理 / Vol.089 / 読者数:976名

こんばんは、うすだです。

雑誌に、CD-ROM や DVD-ROM がついてくることがありますよね。

段ボールのような分厚い紙におさまっていて、ミシン目にそって開封すると、 外に取り出せるようになっている、アレです。

当然のことながら、購入した雑誌にソレがついていると、 開封して中身を拝見するわけですが、わたしは、今まで、 ミシン目にそってきれいに開封できたことがありません。
書いてある通りにやろうとしても、うまくはがせないか、 ミシン目と違うところが裂けていき、 幼児が牛乳パックを無理矢理こじ開けたような状態になってしまいます。 …もうゲンナリです。

みなさんは、アレを、うまく取り出せているのでしょうか。
わたしは、上手に取り出せるひとはあまりいないだろう、と思っているのですが、 あのインターフェースがまったく改善されないところを見ると、 そうでもないのかもしれない、という疑念をいだいてしまいます。

あと、これとは関係ありませんが、CD をケースから取り出すのも、 上手ではありません。CD を割ってしまうのではないか、という恐怖感と戦いながら、 毎回取り出しております。

世の中には、まだまだ発展途上なことがいっぱいあるのだ、 と前向き(?)にとらえつつ、今週も、はりきってまいりたいと思います。

今週のお題 - ディスクをミラーリングする

大切なデータを保存しているディスクは、ディスクが突然壊れたときなどのために、 当然バックアップをとりますよね。
しかし、バックアップをとってから、ディスクが壊れるまでの間のデータは、 さすがに失われてしまうことが多いのではないかと思います。

作業を再び行うことで、リカバリーできることもあるかもしれませんが、 それでは済まされないことも、場合によってはあるかもしれません。
とはいえ、バックアップを頻繁にとっていると、パフォーマンスや管理の面で、 いろいろと支障をきたすことになります。

そんなときのために、大事なデータは、ミラーリングされたディスク上に記録する、 というのはいかがでしょうか。
ミラーリングされていれば、どちらかのディスクが壊れても、 もう一方のディスクが無事なら、データが失われることがありません。

というわけで今週は、ディスクをミラーリングする方法を、ご紹介したいと思います。


Linux カーネルには、いわゆる RAID を、 ソフトウェア的に構築して使用するためのドライバが、存在します。 (新しめの 2.4 以降にあります。)
これと mdadm パッケージを使えば、意外と簡単にミラーリングさせることができます。

今回は、2つのパーティションをミラーリングする方法を、 以下の手順でご紹介していこうと思います。

  1. ディスクを用意し、パーティションを2つ作成する。
  2. MD(Multi-device)デバイスを作成する。
  3. MDデバイスをフォーマットして使えるようにする。
  4. OS 起動時に、自動的にマウントして使えるようにする。

ディスクは、できれば2台用意すべきですが、とりあえず試すだけなら、 1台だけでも構いません。 ただし、ディスクが壊れたら、2つとも失われる可能性がありますので、 実運用には、これっぽっちもお勧めしません。
ディスクを2台用意する場合、同じメーカや同じ型番でなくても、ぜんぜん構いません。 また、パーティションのサイズも、きっちり同じである必要はありません。 (小さい方の容量まで使用できます。)


というわけで、まずは、パーティションを作成しましょう。
ディスクが2台ある場合はそれぞれに1つずつ、1台で試す場合は1台に2つ作成します。
パーティションを作成するには、fdisk や cfdisk などのコマンドを実行します。

例として、/dev/hdb 上にある既存のパーティションを削除して、2つ作成する手順を、 以下に示します。(長くてすみません。)

  # fdisk /dev/hdb

  Command (m for help): d         <== パーティションの削除
  Selected partition 1

  Command (m for help): n         <== パーティション1の作成
  Command action
     e   extended
     p   primary partition (1-4)
  p                               <== プライマリを指定
  Partition number (1-4): 1       <== 1番を指定 (サイズは約半分)
  First cylinder (1-260, default 1): 
  Using default value 1
  Last cylinder or +size or +sizeM or +sizeK (1-260, default 260): 130

  Command (m for help): n         <== パーティション2の作成
  Command action
     e   extended
     p   primary partition (1-4)
  p                               <== プライマリを指定
  Partition number (1-4): 2       <== 2番を指定 (サイズは残り全部)
  First cylinder (131-260, default 131): 
  Using default value 131
  Last cylinder or +size or +sizeM or +sizeK (1-260, default 260):
  Using default value 260

  Command (m for help): p         <== パーティションを表示して確認

  Disk /dev/hdb: 134 MB, 134217728 bytes
  16 heads, 63 sectors/track, 260 cylinders
  Units = cylinders of 1008 * 512 = 516096 bytes

     Device Boot      Start         End      Blocks   Id  System
  /dev/hdb1               1         130       65488+  83  Linux
  /dev/hdb2             131         260       65520   83  Linux

  Command (m for help): w         <== 記録して終了
  The partition table has been altered!

  Calling ioctl() to re-read partition table.
  Syncing disks.

パーティションを作成しましたので、次は、MDデバイスという、 仮想的なディスクを作成します。
MDデバイスの作成には、mdadm コマンドを実行します。
実行例を、以下に示します。

  # mdadm -C /dev/md0 -ayes -l raid1 -n 2 /dev/hdb1 /dev/hdb2
  mdadm: array /dev/md0 started.

-C オプションで、直後に指定した /dev/md0 という MDデバイスの作成を指示します。 -ayes オプションを指定すると、/dev/md0 というデバイスファイルがなければ、 勝手に作成してくれます。
-l オプションで、RAID のレベルを指定します。今回はミラーリングですので、 raid1 を指定しています。
-n オプションで、実際に使用するパーティションの個数を指定します。
最後に、使用する実際のパーティションを指定しています。

きちんと設定できたかどうかは、/proc/mdstat を参照することで、確認できます。

  # cat /proc/mdstat 
  Personalities : [raid1] 
  md0 : active raid1 hdb2[1] hdb1[0]
        65408 blocks [2/2] [UU]
        [=======>.............]  resync = 36.0% ...後略...
      
  unused devices: <none>

なにやら矢印が出ていますが、これは、 同期をとっている最中であることを示しています。 同期が終われば、矢印の行が消えます。

また、mdadm コマンドでも、状態を確認できます。
以下のように、-D オプションと MD デバイスを指定します。

  # mdadm -D /dev/md0
  /dev/md0:
          Version : 00.90.03
    Creation Time : Fri Jul 14 13:40:14 2006
       Raid Level : raid1
       Array Size : 65408 (63.89 MiB 66.98 MB)
      Device Size : 65408 (63.89 MiB 66.98 MB)
     Raid Devices : 2
    Total Devices : 2
  ...中略...

      Number   Major   Minor   RaidDevice State
         0       3       65        0      active sync   /dev/hdb1
         1       3       66        1      active sync   /dev/hdb2

MDデバイスが作成できたら、早速フォーマットして使ってみましょう。
たとえば、ext3 ファイルシステムとして使いたい場合は、 以下のように mkfs.ext3 コマンド(またの名を mke2fs)を実行します。

  # mkfs.ext3 /dev/md0

そして、実際にマウントします。
以下では、/mnt/data というディレクトリにマウントしています。

  # mount /dev/md0 /mnt/data
  # ls /mnt/data
  lost+found/

あとは、煮るなり焼くなり、ご自由にお使いください。


さて、ミラーリングの設定ができましたので、最後に、 恒久的に使用するための設定を行いたいと思います。
そのためにはまず、/etc/mdadm.conf というファイルを作成します。
/etc/mdadm.conf の例を、以下に示します。

  DEVICE /dev/hdb*
  ARRAY /dev/md0 level=raid1 num-devices=2 UUID=云々...

1行目は、実際のパーティションを指定します。上記のような、 ワイルドカード等による曖昧な指定で、問題ないようです。
2行目は、mdadm -Ds を実行したときの出力結果そのままです。
というわけで、以下のようにして作成すればよさそうです。

  # cat > /etc/mdadm.conf
  DEVICE /dev/hdb*
  (Ctrl-d を押下)
  # mdadm -Ds >> /etc/mdadm.conf

そして、/etc/fstab に、たとえば以下の1行を追加します。

  /dev/md0   /mnt/data   ext3   defaults    1 3

これで、次に OS が起動される際には、/mnt/data がマウントされます。
(/etc/rc.d/rc.sysinit で mdadm が呼ばれ、 /etc/mdadm.conf の設定が自動的に行われるためです。)


以上、mdadm を用いたミラーリングの設定方法を、ご紹介しました。
ミラーリングをソフトウェアで行いますので、ディスクをあまり選ばないのが、 お気軽でよいですね。

ただ、パフォーマンス的には、あまりよくないかもしれません。
そのあたりは、実際のデータの重要性などを考慮して、場合によっては、 ハードウェアで行うものを使用するなど、 別の方法も検討する必要があるのではないかと思います。

宿題の答え

先週の宿題は、

  暗号化されたファイルを一部変更して、復号化されないことを確認して
  みましょう。

でした。

以下のように、確認してみました。

まず、適当なファイルを暗号化して、テキスト形式で出力します。

  % gpg -a -o hosts.gpg -r "USUDA Hisashi" -e /etc/hosts

そして、適当なエディタ(vi など)を立ち上げ、中身を改竄します。
たとえば、先頭の4行が、以下のようになっていたとします。

  -----BEGIN PGP MESSAGE-----
  Version: GnuPG v1.4.5 (GNU/Linux)

  hQIOAynGV2R2UTcZEAf/bq1cTFDaKZCpxTosgEuFuFYTWwRQS/DW3HMmIlR9Gl8u

どこを変更してもいいですが、あとで簡単に戻せるように、 最後の u を U にしてみましょう。
暗号化ファイルを変更して保存したら、以下のように復号化を試みます。

  % gpg -o hosts -d hosts.gpg
  gpg: CRCエラー。271706 - f6c653
  gpg: encrypted_mdc packet with unknown version 255

…チェックサムが一致しなくなったため、叱られてしまいました。

ちなみに、--ignore-crc-error オプションをつけて、 CRCエラーをスルーさせられます。しかし、大抵は別のエラーが発生しますし、 もし復号化に成功したとしても、

  gpg: 警告: 暗号化されたメッセージは改竄されています!

なんていう、オソロシイ警告が発せられます。
ですので、こっそり改竄する(される)のは、かなり難しそうですね。

今週の宿題

今週の宿題は、

  ミラーリングされたディスクを、いずれか一方のパーティションだけで
  使えるかどうか、試してみましょう。

です。

いずれか一方のパーティションが壊れたと仮定し、 正常なパーティションだけで使用できるかどうかを、試してみてください。
以下のように、アンマウントして MDデバイスを停止させてから、お試しください。

  # umount /mnt/data
  # mdadm -S /dev/md0

あとがき

ここのところ、雨後のタケノコのように、 仮想化ソフトウェアがつぎつぎとフリーで公開されているようですね。

先日も、VirtualBox という、x86 を仮想化するソフトが、 個人利用かつお試しに限られますが、無償利用できるようになりました。
(機能が限定されますが、ソースが公開されている GPL 版もあります。)

独 Innotek 社の VirtualBox
http://www.virtualbox.org/

VMware 並に動作し、USB をサポートするなど、いろいろ機能がそろっているようです。 USB をゲスト OS 上で使いたい病にかかっているわたくしとしましては、 とても嬉しい逸品だと言えます。

面白いのは、 RDP(Windows のリモートデスクトップのプロトコル)経由でゲスト OS にアクセスできるところでしょうか。
(実際、別の Linux マシンから rdesktop でつながりました。)

というわけで、ここ数日間、ちょこちょこと試して遊んでいました。
基本的な設定や操作は GUI で簡単にできますので、楽チンです。
ただ、すんなりと起動しないときがあったり、 USB を使うには usbfs に(自分の権限で)読み書きできないといけなかったりなど、 いくつか細工が必要でした。ネットワークの設定も、よくわからないため、 今のところは使えていません。

とはいえ、それなりに高速かつ安定動作しますし、SDK なんかもあるようですので、 いろいろ楽しめそうです。
VMPlayer に不満のあるかたは、一度試してみてはいかがでしょうか。

 

今週も、ここまで読んでいただき、ありがとうございました。
それでは、また来週に、お会いしましょう!

 

「いますぐ実践! Linux システム管理」の解除は、以下からできます。
http://www.usupi.org/sysad/ (まぐまぐ ID:149633)

バックナンバーは、こちらにほぼ全部そろっています。
http://www.usupi.org/sysad/backno.html

「栗日記」−年始ちょっと過ぎは、年賀状効果でアクセスが増えます。
http://www.usupi.org/kuri/ (まぐまぐ ID:126454)
http://usupi.seesaa.net/ (栗日記ブログ)
http://www.fumido.co.jp/kuriniki/ (栗日記ぎゃらりー)


[バックナンバーのトップへ] [Linux システム管理のトップへ]

トップ

バックナンバー
    [日付順] [目的別]

プロフィール

▼ リンク

独学Linux
Linuxデスクトップ環境に関する情報が満載です。 メルマガもありますよ。
Server World
CentOS 5 をサーバとしたときの設定例が、これでもかというくらいたくさん載っています。 CentOS以外のディストリビューションや、Solaris10の例も充実しています。
LINUXで自宅サーバーを構築・導入(Fedora8)
Fedora8のインストールの仕方から管理方法まで、詳しく載っています。 SearchManには情報がもりだくさんです。
マロンくん.NET
〜サーバ管理者への道〜
Linuxをサーバとして使用するための、いろいろな設定方法が載っています。 マロンくんもかわいいです。 なんといっても、マロンくんという名前がいいですね!!
日本の Linux 情報
日本の、Linux 総本山的なところです。
Linux Square − @IT
@ITが提供する、Linux の情報が満載。 載っていない設定方法はないんじゃないでしょうか。
Open Tech Press
Linux に限らず、オープンソース関連の記事が網羅されています。
ITmediaエンタープライズ:Linux Tips 一覧
Tips というより FAQ 集でしょうか。わからないことがあれば覗きましょう。
IBM developerWorks : Linux
開発者向けですが、勉強になりますよ。
Yahoo!ニュース - Linux
Yahoo!のLinuxに関するニュース一覧です。
栗日記
システム管理とかと全然関係ありませんが、毎日栗の絵を描いています。
システム管理につかれちゃったとき、癒されたいときに、ご覧ください。:-)
WEB RANKING - PC関連
ランキングに参加してみました。押してやってください。

▼ 作ってみました

Add to Google

▼ せんでん





▼ 最近読んだ本

ハリー・ポッターと不死鳥の騎士団 ハリー・ポッターと不死鳥の騎士団
J.K.Rowling
  ハリポ月刊なので読み直してます
ハリー・ポッターと炎のゴブレット ハリー・ポッターと炎のゴブレット
J.K.Rowling
  ハリポ月刊なので読み直してます
ハリー・ポッターとアズカバンの囚人 ハリー・ポッターとアズカバンの囚人
J.K.Rowling
  ハリポ月刊なので読み直してます
ハリー・ポッターと秘密の部屋 ハリー・ポッターと秘密の部屋
J.K.Rowling
  ハリポ月刊なので読み直してます
ハリー・ポッターと賢者の石 ハリー・ポッターと賢者の石
J.K.Rowling
  ハリポ月刊なので読み直してます
アルケミスト アルケミスト
パウロ・コエーリョ
  また読んだ
賢者の書 賢者の書
喜多川 泰
  違った視点から見られてよかった
セキュリティウォリア セキュリティウォリア
Cyrus Peikari, Anton Chuvakin
  やや冗長…ためにはなりました
CORE MEMORY CORE MEMORY
John Alderman, Mark Richards
  この筐体でPC作ってほしい!
新訳 星の王子さま 新訳 星の王子さま
サン=テグジュベリ
倉橋 由美子
  つまらない大人になったのか…
.....

[X]
「センネン画報」 今日 マチ子
「粟津潔 デザインする言葉」 粟津潔
「Binary Hacks」 高林 哲,鵜飼 文敏,佐藤 祐介,浜地 慎一郎,首藤 一幸
「Make: Volume01」 オライリー・ジャパン
「セーラが町にやってきた」 清野 由実
「手紙屋」 喜多川 泰
「Linuxカーネル2.6解読室」 高橋 浩和,小田 逸郎,山幡 為佐久
「人蕩し術」 無能 唱元
「子育てハッピーアドバイス2」 明橋 大二, 太田 知子
「ラッセル幸福論」 B. Russell
「それでも人生にイエスと言う」 Viktor Emil Frankl
「子育てハッピーアドバイス」 明橋 大二, 太田 知子
「考具」 加藤 昌治
「北欧デザイン<3>」 渡部 千春
「北斎の謎を解く」 諏訪 春雄
「体感美術館」 平野 暁臣
「チベット永遠の書」 Theodore Illion
「リナックスの革命」 Pekka Himanen
「人月の神話」 Frederick Phillips,Jr. Brooks
「ヤバい経済学」 Steven D. Levitt, Stephen J. Dubner
「小布施ッション<2001-2002>」 セーラ・マリ カミングス
「アンパンマン伝説」 やなせ たかし
「夢をかなえるゾウ」 水野 敬也
「ゲーム開発者のためのAI入門」 David M. Bourg, Glenn Seemann
「北欧デザイン<2>」 渡部 千春
「北欧デザイン<1>」 渡部 千春
「ヒューマン2.0」 渡辺 千賀
「中国・ロシア同盟がアメリカを滅ぼす日」 北野 幸伯
「超ロング・セラー 絶滅寸前商品」 湯浅 豊彦
「The BUG(ザ・バグ)」 すずき ひろのぶ,かとう みつあき
「デザインのデザイン」 原 研哉
「マキアヴェッリ語録」 塩野 七生
「ハンバーガーを待つ3分間の値段」 斎藤 由多加
「星の旅人-スペイン「奥の細道」-」 黛 まどか
「食品の裏側」 安部 司
「On Lisp」 Paul Graham
「ぼくが医者をやめた理由 つづき」 永井 明
「あなたならどうする?」 Jack Nikolaschka
「セキュアプログラミング−失敗から学ぶ設計・実装・運用・管理」
      Mark G. Graff, Kenneth R. van Wyk
「「左利き」は天才?−利き手をめぐる脳と進化の謎
      David Wolman
「自分の中に毒を持て」 岡本 太郎
「アトピーの薬を減らす本」 田中 貴子
「岡本太郎「明日の神話」修復960日間の記録」 吉村 絵美留
「X51.ORG THE ODYSSEY」 佐藤 健寿
「アレルギーっ子の暮らし応援BOOK」 佐藤 のり子
「沖縄文化論」 岡本 太郎
「「伝説の社員」になれ!」 土井 英司
「コンピュータの構成と設計(上)」 Patterson & Hennessy
「カラスのジョンソン」 明川 哲也
「ドリルを売るには穴を売れ」 佐藤 義典
「頭がよくなる照明術」 結城 未来
「クロフォードのインタラクティブデザイン論」 Chris Crawford
「いじめの根を絶ち子どもを守るガイド」 Barbara Coloroso
「非常識のすすめ―逆発想の仏教論」 ひろさちや
「Linuxアドバンストネットワーク構築ガイド - HAサーバ構築編」
      デージーネット
「イノベーションの達人!」 Tom Kelly, Jonathan Littman
「クリエーター50人が語る創造の原点」 小原 啓渡
「欺術 - 史上最強のハッカーが明かす禁断の技法」 Kevin Mitnick
「楽しい気象観察図鑑」 武田 康男
「入門 Ajax」 高橋 登史朗
「リリカルな自画像」 岡本 太郎
「やぎの目ゴールデンベスト」 林 雄司
「初めてのPython 第2版」 Mark Lutz,David Ascher
「鼻兎」 小林 賢太郎
「なぜ、これがアートなの?」 Amelia Arenas
「芸術起業論」 村上 隆
「まほう色の瞳」 Enrique Barrios
「ラーメンズつくるひとデコ」 ラーメンズ
「R25 つきぬけた男たち」 R25編集部
「美の呪力」 岡本 太郎
「しろのあお」 上大岡 トメ
「ザ・ゴール」 Eliyahu M. Goldratt
「ハッカーと画家」 Paul Graham
「岡本太郎に乾杯」 岡本 敏子
「Fedore Core Expert」 Software Design
「誰も知らない男」 ブルース・バートン
「子どもが育つ魔法の言葉」 ドロシー・ロー・ノルト
「国家の罠」 佐藤 優
「夜回り先生」 水谷 修
「やぎの目絵日記」 林 雄司
「7つの習慣」 スティーブン・R. コヴィー
「まろ、ん?−大掴源氏物語」 小泉 吉宏
「ザ・サーチ グーグルが世界を変えた」 ジョン・バッテル
「ポストモダン・マーケティング」 スティーブン ブラウン
「機動戦士ガンダムさん」 大和田 秀樹
「小エロのひみつ - Webやぎの目研究発表」 林 雄司
「これ、誰がデザインしたの?」 渡部千春
「60分間・企業ダントツ化プロジェクト」 神田 昌典
「ガルシアへの手紙」 エルバート ハバード
「人生は素晴らしいものだ」 オグ・マンディーノ
「ザ・マインドマップ」 トニー・ブザン,バリー・ブザン
「ワインバーグのシステム思考法」 G.M.ワインバーグ
「渋谷ではたらく社長の告白」 藤田 晋
「渋井真帆の日経新聞読みこなし隊」 渋井 真帆
「コラム息切れ」 小野 法師丸
「早朝起業」 松山 真之介
「変な人が書いた驚くほどツイてる話」 斎藤 一人
「35歳から仕事で大切にしたいこと」 村井 勉
「金融広告を読め」 吉本 佳生
「発想する会社!」 トム・ケリー,ジョナサン・リットマン
「エハイク」 吉田 戦車
「人生の旋律」 神田 昌典
「仕事の思想」 田坂 広志
「CPUの創りかた」 渡波 郁
「非常識な成功法則」 神田 昌典
…これ以前は記録してません…

▼ 気に入ってる本

夢をかなえるゾウ 夢をかなえるゾウ
水野 敬也
  いままでで最高の「笑える」成功本
Linuxデバイスドライバ Linuxデバイスドライバ
Alessandro Rubini,
Jonathan Corbet
  ドライバ作らなくてもためになる
Firefoxの改造テクニック! Firefoxの改造テクニック!
大浦 淳
  いま栗日記拡張を考えてます
Apacheモジュール プログラミングガイド Apacheモジュール プログラミングガイド
小山 浩之
  Apacheの中身もわかるよ
図解 実戦マーケティング戦略 図解 実戦マーケティング戦略
佐藤 義典
  栗日記も戦略的に行こう!
やぎの目ゴールデンベスト やぎの目ゴールデンベスト
林 雄司
  よめも爆笑してました
アルケミスト アルケミスト
パウロ・コエーリョ
  ヘコみそうなとき読みます
X51.ORG THE ODYSSEY X51.ORG THE ODYSSEY
佐藤 健寿
  X51.ORGの集大成
チベット永遠の書 チベット永遠の書
Theodore Illion
  いろんな意味ですごい!!
影響力の武器 影響力の武器
ロバート・B・チャルディーニ
  思わず納得します