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

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


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

こんばんは,うすだです.

今,『成功読書術』という本を読んでいます.
http://www.amazon.co.jp/exec/obidos/ASIN/4777101193/usupiorg-22

アマゾンの元バイヤーである土井さんが,古典ともいえる書籍30冊を, 簡潔に紹介されています.土井さんの鋭い考え方や視点が含まれていて, 単なる本の紹介になってないところが,面白いです.

さて,その序章に,良い本を選ぶためのポイントがいくつか書かれているのですが, その中の1つに,ぐっと来ました.

  詳細なエピソードがあるかどうかを見極める

やっぱり,ぱっと思いついたことではなく,実際に経験して, それなりに役に立ったことを, ご紹介していかないといけないなあ…と思いました.
でも,そのためには,日々勉強して,実際に試す,というのを, 常に繰り返さないといけないわけですね.が,がんばります….

しかし,こういう本を読むと,読みたい本がどんどん増えていきますね.
読み返さない本は,古本屋やマーケットプレイスに出して減らしていかないと, 本棚がえらいことになってしまいそうです.
…いや,もうすでにぼとぼととあふれて,えらいことになっていました.

それでは,今日も,はりきってまいりましょう!

今週のお題 - tcp_wrapper でログをとる

今週は,長年温存していたネタである,tcp_wrapper をご紹介します.

tcp_wrapper は,TCP または UDP の接続を,監視・制限するためのものです.
もともとは,inetd 経由で起動されるデーモンを対象としていたように思いますが, 最近(でもないかも)では,sshd や sendmail など, inetd に依存せずに動作するデーモンも,ぞくぞくと対応しているようです.
(知らずに厳しく制限して,ssh で遠隔ログインできなくなってしまった! …なんてことが,昔あったような気がします.)

制限に関しては,すでにパケットフィルタリングがあるから, tcp_wrapper を使用する意味がないのではないか,と思われるかもしれません.
ですが,tcp_wrapper では,ドメイン名を用いた柔軟な設定を行うことができますし, アクセスがあった時にさまざまなアクションを起こすことができます. また,多層防御という点でも,ある程度有効ではないかと思います. ですので,導入する意味は,それなりに十分あると思います.

さて,今週は,アクセスされたことを,ログに記録してみたいと思います.
アクセス制限の設定方法については,来週ご紹介します.

まず,inetd あるいは xinetd 経由で起動されるデーモンを, tcp_wrapper 対応にします.ここでは,telnet を対象としてみます.
xinetd の場合,/etc/xinetd.d/telnet を,以下のようにします.

  service telnet
  {
      disable = no
      flags           = REUSE NAMEINARGS
      socket_type     = stream
      wait            = no
      user            = root
      server          = /usr/sbin/tcpd
      server_flags    = /usr/sbin/in.telnetd
      log_on_failure += USERID
  }

変更点は,以下の通りです.
(telnet 以外で試す時は,以下を参考にしてください.)

  • flags に NAMEINARGS を追加します.
  • server を /usr/sbin/tcpd に変更します.
  • server_flags を追加します.
    値は,変更前に server に指定していた内容そのままです.

inetd の場合は,/etc/inetd.conf の telnet の行を,以下のように変更します.

  telnet stream  tcp  nowait  root  /usr/sbin/tcpd  in.telnetd

ちなみに,Vine や Debian では,最初から,このようになっていました.
*BSD の方は,変更が必要だと思います.

xinetd は設定ファイルを変更するだけですが,inetd の場合, inetd.conf を変更したら,以下を『必ず』行ってください.

  # kill -HUP `cat /var/run/inetd.pid`

次に,どのような監視や制限を行うのか,ということを指定します.
そのためのファイルが,/etc/hosts.allow と /etc/hosts.deny です.
前者が,アクセスの許可の指定に,後者が拒否の指定に,使われます.
いずれも,先頭から1行ずつ参照し,一致した行の設定に従います.
いずれにも一致しない場合は,許可されます.

今回は,ログに記録するだけですので,/etc/hosts.allow に仕込んでみることにします.

設定自体は,どちらのファイルも同じで,以下のような書式を用います.

  デーモン : クライアント : アクション

デーモンには,実際に起動されるデーモンのプロセス名を指定します.
例えば,telnet の場合は,in.telnetd です.
, で区切って,複数のデーモンを指定することもできます.
また,ALL と指定すると,すべてを対象にします.

クライアントには,許可(あるいは拒否)するクライアントを指定します.
これについては,来週ご紹介します.

アクションには,シェルのコマンドを指定します.省略可能です.

ではでは,/etc/hosts.allow の例を,以下に示します.

  in.telnetd : ALL : spawn (/usr/bin/logger -i -p auth.info \
      %d\: connected from %h) &

telnet に対して,(ALL なので)すべてのクライアントを許可しています.
…なんじゃそりゃ,意味ないじゃん,と思われるかもしれませんが, ここで大事なのは,アクションの部分です.telnet に対してアクセスがあると, logger コマンドを用いて,syslog にログを書き込んでくれます.

おっと,ここで,logger の引数がちょっと気になりますね.
\: としているのは,そもそも : が区切りを示す特別の意味を持っているため, 単なる文字として解釈してもらうよう,\ を付加しています.
また,%d と %h というものがありますが,実際に起動される時に,それぞれ, デーモンのプロセス名,クライアントのホスト名かIPアドレスに, 置き換わります.
他にもいろいろ指定できます.詳しくは,オンラインマニュアルを,ご覧ください. (man 5 hosts_access を実行してください.)

せっかくですので,実際に,試してみましょう.
別のマシンから,telnet コマンドでアクセスしてみます.

  client% telnet server
  Trying 192.168.1.1...
  Connected to server.
  Escape character is '^]'.
  ...後略

/var/log/messages を見ると,以下のように記録されています.
(Debian だと /var/log/syslog ですね.)

  # grep logger /var/log/messages
  ...前略
  May 29 10:10:42 server logger[8013]: in.telnetd: connected from \
  192.168.1.252

これで,192.168.1.252 というマシンから,telnet にアクセスされたということが, ログに残るようになりました.

syslog に対応していないデーモンには,有効な手段だと思います.
他にも,アクションの部分を,メールの送信にするなど, いろいろ応用ができるのではないかと思います.

ちなみに,xinetd は,tcp_wrapper を使わなくても, アクセス制限もログの記録も行うことができます.
余力のある方は,調べて,試してみてください.

宿題の答え

先週の問題は,

  メールで通知しつつ,ログも残してくれる,CustomLog 用のプログラム
  を作ってください

でした.
プログラムを作ってください,などと言ってしまいましたが,実は, 作らなくても,CustomLog を2つ設定すれば,あっさり解決します.
その方法は,httpd.conf に,以下を記述するだけです.

  CustomLog /var/log/httpd/ssh_log combined env=ssh_log
  CustomLog "|/usr/local/sbin/sshnotice.pl" combined env=ssh_log

/var/log/httpd/ssh_log にログが記録されつつ, 先週のプログラムである sshnotice.pl 経由でメールの通知も行われます.

今週の宿題

今週の宿題は,こちらです.

  telnet に対してアクセスがあった時に,メールで root に通知する設定
  を,/etc/hosts.allow に行ってください

またメールで通知かよ,と思われたのなら,ごめんなさい….
でも,これが,いちばん便利なんですよね.

あとがき

ご紹介した『成功読書術』の土井さんは,メルマガも出されています.

ビジネス・ブック・マラソン
http://www.mag2.com/m/0000135008.htm

毎日,1冊の本を,紹介されています.
しかし,毎日毎日,本を何冊も読むって,仕事とはいえ,すごいですね.
(同じ人間とは思えません….)

実は,去年,土井さんの講演を拝見する機会がありました.
最初,すごく頭が切れるひとだなあ,と思いましたが, すごく熱く語られているのを見て,本に対する愛情というか情熱を, ひしひしと感じました.

今週は前ふりが長かったので,あとがきはこのくらいでおわりにします.

しつこいようですが,システム管理に関するネタや悩み,疑問などがありましたら, 遠慮なくメールでご連絡ください.
内容がなんであれ,作者が感激します.返事はかならずしますよー.

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

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

バックナンバーは,こちらにまとめてあります.
http://www.usupi.org/sysad/backno.html

「栗日記」もやってます.
http://www.usupi.org/kuri/ (まぐまぐ ID:126454)

クリエーターズマーケットに出店します.6/19 のみ.どうしよう…
http://www.creatorsmarket.com/


[バックナンバーのトップへ] [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・チャルディーニ
  思わず納得します