検索
連載

サーバのログ監視ツールを使いこなそうLinux管理者への道(4)(2/3 ページ)

ログを取得しても、監視していなければ意味がない。しかし、常時監視するのは現実的ではない。異常の発生をメールで通知させるなどの対策を行っておこう。(編集局)

PC用表示 関連情報
Share
Tweet
LINE
Hatena

swatchによるログの常時監視

 ログを監視して、特定の文字列が出力されると管理者へ知らせるツールとして「swatch」があります。syslogdのマニュアルには「異常なログをメールで送信するようでは手遅れである」と書かれていますが、実際問題としては対応が遅れることになってもメールで異常を確認できる方が良い環境もあると思われます。

 また、ログをリアルタイムで監視しているため、不正アクセスされてローカルのログの改ざんが行われた際も、swatchが起動していれば必要な情報を転送しておくことなどが可能です。このように、swatchを使えばセキュリティと運用面で有効な仕組みを作ることができます。

swatchのインストール

 swatchの最新のバージョンは3.0.4です(2002年11月2日現在)。http://www.oit.ucsb.edu/~eta/swatch/からswatch-3.0.4.tar.gzファイルをダウンロードします。

 また、swatchはPerlで記述されたプログラムであり、Perl5()のほかに、

  • Date::Calc
  • Date::Parse
  • File::Tail
  • Time::HiRes

の4つのモジュールが必要です。CPANのサイト(Perlのフリーモジュールがダウンロードできる)http://search.cpan.org/から上記の4モジュールをダウンロードします。上記サイトにアクセスすると、トップページが検索画面になっています。各モジュールを検索してダウンロードします。

注:Perl(Perl5)はすでにインストール済みという前提で進めます。

 2002年11月現在の最新モジュールファイルは以下になります。

 wgetあるいはWebブラウザを利用してダウンロードしましょう。

 ではインストールです。各Perlモジュールのインストール方法は同じです。ここでは、ダウンロードしたファイルを保存したディレクトリを$SOURCEとし、Date::Calcを例に説明します。

*** 一部省略されたコンテンツがあります。PC版でご覧ください。 ***

 4つのモジュールをインストールしたら、swatchをインストールします。

*** 一部省略されたコンテンツがあります。PC版でご覧ください。 ***

swatchの設定

 swatchの設定ファイルは、デフォルトでは~/.swatchrcです。swatchには設定ファイルのサンプルが含まれているので、このサンプルファイルを規定のディレクトリにコピーしてひな型ファイルとして利用します。

 なお、サンプルファイルには、

  • $SOURCE/swatch-3.0.4/examples/swatchrc.monitor
  • $SOURCE/swatch-3.0.4/examples/swatchrc.personal

の2種類があります。

 swatchrc.monitorには、サーバへの不正アクセスやハードの発熱、システムのクラッシュや停止、再起動の監視を行うためのサンプル設定が記述されています。

 swatchrc.personalでは、swatchrc.monitorの内容に加えて、特定プログラムの実行監視とそれ以外のすべてのログをコンソール上に表示する設定が行われています。swatchrc.monitorの内容はおおむねswatchrc.personalにも設定されているため、swatchrc.personalをコピーして編集します。これをホームディレクトリ()に「.swatchrc」としてコピーします。

*** 一部省略されたコンテンツがあります。PC版でご覧ください。 ***

注:/var/log/ディレクトリ内のログファイルの多くは、root権限でなければ読み込めません。一般ユーザーでもswatchを実行することは可能ですが、監視対象のログファイルに読み取り権限が必要です。ここでは、rootユーザーでswatchを実行しています。

 設定ファイルで指示する内容は、監視する文字列および文字列発見時の処理方法です。上から下へ、記述された「パターン」にマッチしているかどうかを順番にチェックしていきます。パターンにマッチすると、それに対応する「アクション」を実行して終了します。

 設定ファイルの書式は以下のようになります。

*** 一部省略されたコンテンツがあります。PC版でご覧ください。 ***

1.パターン

 監視したい文字列を、watchforの後に「/」で挟んで記述します。

 ここで記述するパターンにはPerlの正規表現を使用することができます。swatchで一般的に使用される正規表現として、「faile|error」などのように「|」で区切ってfaileかerrorをマッチさせるパターン、「[Ll]inux」のように記述してLinuxとlinuxの両方にマッチさせるパターン、任意の1文字を表す「.」を「a.c」のように文字間に記述してaで始まりcで終わる3文字の文字列にマッチさせるパターンがあります。「/faile/,/error/」のように区切ることで、複数のパターンを指定することもできます。パターンの最後に「/faile/i」のように「i」を付ければ、パターンの大文字小文字を区別しなくなります。

 また、watchforの代わりにignoreを指定して、特定の文字列を含む行を無視させることも可能です。なお、ignoreはwatchforより上に記述します。

2.アクション

  アクションには、パターンがマッチした場合の処理を記述します。指定できるアクションには、以下のようなものがあります。

アクション 説明
echo [modes] ターミナルにメッセージを表示。modesにより表示形式を変更可能
bell [N] beep音をN回鳴らす。数字を指定しなければ1回
exec command 指定したコマンドを実行する。コマンドの引数として「$0」を指定すると、表示されるログそのものを意味する。「$N」は、N番目のフィールドの文字列を意味する
mail [=address:address:…][,subject=your_text_here] 指定されたアドレスにメールを送信する。メールは複数指定できるほか、サブジェクトの指定が可能。アドレスを指定しなければswatchを起動したユーザーに送信される
pipe command[,keep_open] パイプでコマンドに結果を渡す。keep_openを指定すると異なるパイプが実行されるか、swatchが終了するまでパイプが実行されたままになる
write [user:user:…] swatchを実行しているサーバにログインしているユーザーに、writeコマンドを使用して結果を送信する
throttle hours:minutes:seconds,[use=message|regex] 一度検出されたパターンが再度検出された場合、検出を抑えることができる。標準では「use=messges」が指定されており、同じmessagesは検出されない。「use=regex」を指定すると、同じ正規表現の場合は検出されない
continue 通常は、マッチするパターンが検出されると指定されたアクションが実行されて終了するが、continueが指定されている場合はさらにマッチするパターンの検出が行われる
quit マッチするパターンを検出するとswatchが終了する
表1 アクションの種類と機能

 echoのmodesには、以下のようなものを指定できます。

modes 説明
normal 通常の表示
bold 太字で表示
underscore 下線で表示
blink 点滅で表示
inverse 反転して表示
[color] black、red、green、yellow、blue、magenta、cyan、whiteの色で表示
[color_h] black_、red_h、green_h、yellow_h、blue_h、magenta_h、cyan_h、white_hの色で反転
random 上記のものをランダムに使用
表2 echoに指定できるmodes
注:コンソールによっては、表示形式が正常に反映されないものがあります。

 swatchrc.personalをコピーした.swatchrcを基に、設定ファイルを作成します。もちろん、使用するプログラムやディストリビューションによって出力されるログは異なりますし、監視すべき内容も変わってきます。ここでは設定例を挙げてみます。

*** 一部省略されたコンテンツがあります。PC版でご覧ください。 ***

swatchの起動

 swatchの設定が終了したら、swatchを実行します。バックグラウンドで動作させるために、「&」を引数に実行します。

*** 一部省略されたコンテンツがあります。PC版でご覧ください。 ***

 sshやtelnetなどで、わざと認証に失敗してみましょう。メッセージがコンソールに表示されるのが確認できます。

 今回のように、特にオプションを指定しない場合は、

*** 一部省略されたコンテンツがあります。PC版でご覧ください。 ***

のようなオプション指定で実行され、/var/log/messagesファイルを監視します。/var/log/messagesファイルが存在しない場合は、

*** 一部省略されたコンテンツがあります。PC版でご覧ください。 ***

が実行されてmessagesの代わりに/var/log/syslogを監視します。

 これらのオプションの詳細は、表3を参照してください。

*** 一部省略されたコンテンツがあります。PC版でご覧ください。 ***

 一般的なswatchの使用方法は、

*** 一部省略されたコンテンツがあります。PC版でご覧ください。 ***

です。

 ログファイルはmessagesファイルだけではなく、テキストファイルとして読み出せるものであればどのファイルでも指定できます。複数のログファイルを異なる内容で監視したい場合は、swatchを複数起動します。オプションの指定を変更して、swatchを複数回実行しましょう。

 ~/swatchrcが存在しない状態で、オプションで設定ファイルを指定しなかった場合は、

*** 一部省略されたコンテンツがあります。PC版でご覧ください。 ***

の内容で実行されます。「.*」は、正規表現において「任意の文字が1文字以上連続すること」を意味します。よって、あらゆる行をランダムな形式で表示します。

 システムの起動時にswatchを自動起動させたい場合は、/etc/rc.localなどに以下の行を追記します。

*** 一部省略されたコンテンツがあります。PC版でご覧ください。 ***

Copyright © ITmedia, Inc. All Rights Reserved.

ページトップに戻る