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

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


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

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

この間、会社宛に、英語の電話がかかってきました。

わたしはほとんど英語が話せないので、電話口でおろおろしていますと、 そのうちカタコトの日本語で、なんとか会話してくださいました。

結局趣旨がわからず、本社にかけてください、と日本語でお願いすると、 とりあえずメールで質問をいただくことになりました。

まあ、わたくしのような末端の社員が、恐れおおくも応対することはないと思い、 メールが来たら誰かにお願いしようと、そのとき思いました。

しかし、その後数日たってますが、それらしきメールがやってきません。
鈍いわたくしも、今から思うと、 ソーシャルエンジニアリングというやつだったのではないか、という気がしてきました。

以前にも、英語と日本語の交じった変な電話があり、 名前やらを聞かれたことがありました。 (その後、転職を勧める妙なメールが来ました…。)

英語で問合せると、受け側は焦って余裕がなくなり、 隙ができていろいろ聞き出せるということかと、いまさらながらしております。
みなさんも、英語のアヤシイ電話には、十分ご注意ください。

あーなんだかとってもクヤシイですが、そんなことは早く忘れて、 今週も、はりきってまいろうと思います。

今週のお題 - DHCP サーバを動かす / アポカリプス

先週、DHCP サーバの設定方法の、ごくごく基本的なところをご紹介したところで、 終わってしまいました。

Vol.080 - DHCP サーバを動かす
http://www.usupi.org/sysad/080.html

今週はその続きで、個別設定とリレーエージェントの2つを、 ご紹介しようと思います。
どちらかでも構いませんので、目を通していただけますと、幸いです。


DHCP クライアントがみんな同じようなクライアントで、平等かつ公平に、 動的な IP アドレスを割り振ればいいってことであれば、 先週の最小限的設定でこと足りるんじゃないかと思います。

しかしながら、あるひとには固定のアドレスを割り振らないといけない、 というニーズに答える必要も、ときにはあるのではないかと思います。
そんなときには、/etc/dhcpd.conf に以下の設定を加えましょう。
(Debian 系の場合は、/etc/dhcp3/dhcpd.conf です。)

  host ホスト名 {
      hardware ethernet MACアドレス;
      fixed-address 割り当てる固定のIPアドレス;
      その他の設定;
  }

たとえば、MACアドレスが 00:01:02:03:04:05 のマシンに、 192.168.1.99 というIPアドレスを割り当てたい場合は、以下の設定を加えます。

  host test1 {
      hardware ethernet 00:01:02:03:04:05;
      fixed-address 192.168.1.99;
  }

ホスト名には、任意の名前を用いることができますが、 他の host と重複しない名前にする必要があります。
また、上記は、subnet の中でも外でも、どちらに書いても構いません。

 

さて、固定のアドレスを割り当てる必要のあるひとたちは、なにかの端末で、 PXE などでブートするため、 ブートファイル名や TFTP サーバを教えてあげる必要がある、としましょう。
それらの設定を、host 毎に指定するのはとても面倒ですし、 サーバなどが変わったときに書き換えることを考えると、萎えますよね。

そんなときには、group で囲むと、共通の設定をまとめて指定できます。
以下は、filename と next-server の設定を、みんなで共有しています。
(filename でブートファイル名を、 next-server でブートファイルを持つサーバを指定しています。)

  group {
      filename "pxelinux.0";
      next-server 192.168.1.1;
      host test1 {
          hardware ethernet 00:01:02:03:04:05;
          fixed-address 192.168.1.99;
      }
      host test2 {
          hardware ethernet 00:01:02:03:04:06;
          fixed-address 192.168.1.100;
      }
      ...
  }

また、group は、固定でないアドレスを割り当てる場合にも使えます。
たとえば以下のように、MAC アドレスによって、使用するブートファイルを分ける、 という設定を行うことができます。
(test1 と test2 は pxelinux.0 を、 test3 と test4 は bzImage という具合に分けています。)

  subnet 192.168.1.0 netmask 255.255.255.0 {
      range 192.168.1.240 192.168.1.247;
      option routers 192.168.1.254;
      option domain-name-servers 192.168.1.1;
  }

  group {
      filename "pxelinux.0";
      next-server 192.168.1.1;
      host test1 { hardware ethernet 00:01:02:03:04:05; }
      host test2 { hardware ethernet 00:01:02:03:04:06; }
  }

  group {
      filename "bzImage";
      next-server 192.168.1.2;
      option root-path "/export/diskless/share";
      host test3 { hardware ethernet 00:01:02:03:04:07; }
      host test4 { hardware ethernet 00:01:02:03:04:08; }
  }

以上で、dhcpd.conf の基本的な設定のご紹介は、おしまいにします。
最後に、リレーエージェントのご紹介をさせてください。

社内ネットワークが複数のサブネットに分割されている場合、 サブネット毎に DHCP サーバが必要になります。 でも、サブネット毎に DHCP サーバを動かしていると、管理が面倒くさくなります。

ゲートウェイマシン上で動かすという手もありますが、 ゲートウェイからすべてのサブネットが見える場合にしか通用しません。

それでも、DHCPサーバは一つで運用したい、という貴兄もいらっしゃるでしょう。 (わたしも、そう思います。)
そんなときには、リレーエージェントなるものを使うと、解決します。
リレーエージェントは、一方のネットワークからの DHCP クライアントのメッセージを、 別のネットワークに横流ししてくれるひとです。

たとえば、以下のようなネットワーク構成で、192.168.1.0/24 上にいる DHCPサーバが、 192.168.2.0/24 上の DHCPクライアントに、 アドレスなどを割り当てられるようにしてみましょう。

     [DHCPサーバ]
          | 192.168.1.1
          |
          | 192.168.1.254 (eth0)
    [ゲートウェイ]
          | 192.168.2.254 (eth1)
          |
  [DHCPクライアント]

DHCP サーバの dhcpd.conf には、192.168.2.0/24 の情報を記述するだけです。 たとえば、192.168.2.240〜247 を割り当てるための、その部分の最小限的な例を、 以下に示します。

  subnet 192.168.2.0 netmask 255.255.255.0 {
      range 192.168.2.240 192.168.2.247;
  }

そして、192.168.1.0/24 と 192.168.2.0/24 を取り持つゲートウェイ上で、 リレーエージェントを動かします。
リレーエージェントの実行ファイル名は、dhcrelay です。
あ、Debian の場合は、dhcrelay3 です。 これは dhcp3-relay パッケージにありますので、 もしなければ、apt などでインストールしてください。

dhcrelay は、引数に DHCP サーバを指定して実行します。

  # dhcrelay 192.168.1.1

他にもサブネットがあるけれど、そちらからの要求はリレーしたくない、 という場合には、以下のように、リレーを許可するインターフェースを、 明示的に指定します。

  # dhcrelay -i eth1 192.168.1.1

これにより、DHCPクライアントからのブロードキャストな要求が、 リレーエージェントによって DHCPサーバに渡るようになります。

OS 起動時に dhcrelay を動かすようにしたい場合は、 chkconfig などで有効にしてください。
そのときは、DHCPサーバや許可するインターフェースを、記述する必要があります。
Fedora Core 5 や VineLinux 3.2 の場合は、 /etc/sysconfig/dhcrelay の DHCPSERVERS や INTERFACES で指定しましょう。

  INTERFACES="eth1"
  DHCPSERVERS="192.168.1.1"

Debian なかたは、 /etc/default/dhcp3-relay の SERVERS や INTERFACES で指定してください。

ちなみに、ゲートウェイマシンの IP フォワーディングは、 オフになっていても問題ありません。(アプリケーションレベルで横流しするため。)


以上、DHCP サーバの設定方法について、ご紹介しました。

やや急ぎ足かつ、詰め込み気味にご紹介しましたので、 わかりにくかったかもしれません。すみません。
なにはともあれ、なんとなく雰囲気だけでも感じとっていただけますと、 いや、できましたら、お試し環境で試していただけますと、幸いです。

宿題の答え

先週の宿題は、

  同じサブネット内に複数の DHCP サーバが動作しているとき、DHCP で
  アドレスを取得しようとしたら、どうなるでしょうか?

でした。

DHCP 自体が、複数の DHCP サーバがいることを想定しているので、 基本的には問題はありません。

アドレスをもらうときのやりとりを大雑把に書くと、以下のようになると思います。 (RFC2131 より)

  1. DHCP クライアントが DHCPDISCOVER をブロードキャストします。
  2. 割り当て可能な DHCP サーバが、アドレスなどの情報を DHCPOFFER で返します。
  3. クライアントは、複数の DHCPOFFER の中からどれか1つを選びます。
    そして DHCPREQUEST をブロードキャストします。 これには、サーバIDが含まれています。
  4. サーバは、受信した DHCPREQUEST のサーバIDを見て、 自分のIDと一致する場合は、DHCPACK を返します。 ID が一致しなければ、別のサーバから割り当てられたんだなと思ってがっかりします。

ただ、想定していたのとは違うサーバから、 変なアドレスやパラメータを受けとってしまうなどの状況に陥る可能性が、 場合によってはあります。
ですので、DHCP サーバは、サブネット内で1つだけにするか、 複数必要な場合はお互い重複しない設定にしたほうが、無難だと思います。

今週の宿題

今週の宿題は、

  DHCP サーバは、リレーエージェント経由でアドレスを割り当てるとき、
  クライアントのいるサブネットの情報を、どこから得るのでしょうか?

です。

あちこちのリレーエージェント経由で要求が来る DHCP サーバは、 リレーエージェントの向こう側にあるサブネットを、 どのように判別しているのでしょうか。

もし判別していなければ、どのアドレスを割り当てればいいかわからないはずです。 しかし実際には、DHCP クライアントが所属するサブネットのアドレスを、 間違えずに割り当てています。

どこかに、その情報が書かれているはずですが、どこから得ているのか、 パケットをキャプチャしたりして、察しをつけてみてください。
(わたしも、来週までに調べておきます。)

あとがき

以前、Python の勉強を始めたと書きましたが、今もその熱は冷めることなく、 じわじわと歩伏前進的に続いております。(珍しい!)

SoftwareDesign の特集やオレンジニュースなどで、 ちらほらと取り上げられているところを見ると、 実のところは Python ブームが到来しそうになっているのかもしれませんね。 …それは言いすぎですかね。

まあ、世間の動向はあまり気にしないようにして、 以下の書籍やサイトをときどき覗いて勉強してます。 興味のあるかたは、どうぞご覧ください。

初めてのPython 第2版
http://www.amazon.co.jp/exec/obidos/ASIN/4873112109/usupiorg06-22
Python & IronPython 入門
http://www.okisoft.co.jp/esc/python/iron-python-intro.html
Python調査報告
http://cydn.cybozu.co.jp/files/python_survey_at_cydn.html
Pythonでワンライナーを作成する際のノウハウ集
http://www.nishiohirokazu.org/blog/2006/08/python_12.html

 

あと、Ming というライブラリを使って、 Flash ムービーを作ろうとしていたりもしています。

Ming - a SWF output library and PHP module
http://ming.sourceforge.net/

C だけでなく、C++, PHP, Perl, Python, Ruby などからも利用できるのですが、 諸般の事情(?)により、わたしは C で書いています。

使い方をオブラートにつつんでご説明しますと、Flash で行いたい一連の動作を、 Ming の関数を呼んでコーディングします。
いちばん最後に、SWF ファイルを出力する関数を、忘れずに呼びます。
これをコンパイルして実行すると、SWF ファイルが出力されます。

という手順でとりあえずできるのですが、なんだかしっくりきません。
C のコードでは無限ループになっていないのに、ブラウザで確認すると、 延々ぐるぐる廻り続けるんですよね。 といいますか、そもそも無限ループにしてしまいますと、 SWF ファイルの出力までたどり着けませんよね。

たぶん、ひととおり実行したところで最初に戻るようになっているのだと思いますが、 となると生成したオブジェクトなどが、ループ毎に増殖している可能性があります。
Flash はガーベジコレクション様がいてくださるので、 参照されていないオブジェクトは自動的に解放されるはずですが、 自分の目で見て確認したわけではありませんので、もやもや感を払拭できずにいます。

で、なんでこんなことをしているのかと言いますと、じつは、実行例を、 Flash で動くものにしたいからなのです。
(以前作った安直 JavaScript 版は、しょぼかったですので…。)

基本部分を最初に作っておけば、あとは使い回せるだろう、という魂胆でいますが、 今のところ、思い通りのものが生成できていません。

しかし、調べたり試行錯誤しながら、少しずつ覚えていくという作業は、 なかなか楽しいです。うっかり夜なべもしてしまいますね。

途中で飽きずに、それっぽいものができるようになったら、 ソース込みでご紹介したいと思っています。
これっぽっちも期待しないで、でも傍観していただけますと、幸いです。

 

…ああ、またあとがきが長過ぎですね。以後気をつけます。

 

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

 

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

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

「栗日記」−「栗」で検索すると10位内に! しかし、1位はまだ遠い…。
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で自宅サーバーを構築・導入(Fedora9)
Fedora9のインストールの仕方から管理方法まで、詳しく載っています。 SearchManには情報がもりだくさんです。
マロンくん.NET
〜サーバ管理者への道〜
Linuxをサーバとして使用するための、いろいろな設定方法が載っています。 マロンくんもかわいいです。 なんといっても、マロンくんという名前がいいですね!!
Ubun通
Linux(主にUbuntu)と自作PCに関する投稿型情報サイトです。 私の知らない最新のソフトなどが紹介されています。
日本の 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

▼ せんでん




▼ 最近読んだ本

シッダールタ シッダールタ
Hermann Hesse
  何度も読んで理解したい本
新宿駅最後の小さなお店ベルク 新宿駅最後の小さなお店ベルク
井野朋也
  食べてみたくって仕方がありません
第五の山 第五の山
Paulo Coelho
  不可避なことから学べるようになりたい
入門LDAP/OpenLDAP 入門LDAP/OpenLDAP
デージーネット
  超具体的でわかりやすいです
エイジレス革命 エイジレス革命
Deepak Chopra
  固定観念にとらわれないで生きます
免疫革命 免疫革命
安保徹
  免疫力を高めて自力で治すべし!
悪い笛 悪い笛-エハイク2
吉田戦車
  エハイク第二弾。評が絶妙!
ハリー・ポッターと死の秘宝 ハリー・ポッターと死の秘宝
J.K.Rowling
  とうとう最後に…全部読んでよかった
ハリー・ポッターと謎のプリンス ハリー・ポッターと謎のプリンス
J.K.Rowling
  ハリポ月刊なので読み直してます
ハリー・ポッターと不死鳥の騎士団 ハリー・ポッターと不死鳥の騎士団
J.K.Rowling
  ハリポ月刊なので読み直してます
.....

[X]
「賢者の書」 喜多川 泰
「セキュリティウォリア」 Cyrus Peikari, Anton Chuvakin
「CORE MEMORY」 John Alderman, Mark Richards
「新訳 星の王子さま」 サン=テグジュベリ / 倉橋 由美子
「センネン画報」 今日 マチ子
「粟津潔 デザインする言葉」 粟津潔
「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・チャルディーニ
  思わず納得します