人力検索はてな
モバイル版を表示しています。PC版はこちら
i-mobile

Apache のカスタムログ設定で、特定の HTTP ステータスコードのときのみログを出力する方法を教えてください。SetEnvIf で指定できると思って調べてみたのですが、有力な情報が見つかりませんでした。

●質問者: naoya_nakazawa
●カテゴリ:コンピュータ インターネット
✍キーワード:Apache HTTP カスタム ステータスコード ログ
○ 状態 :終了
└ 回答数 : 1/1件

▽最新の回答へ

1 ● b-wind
●60ポイント

通常リクエストに応じてログを制御する場合、 SetEnvIf や mod_rewrite を使いますが

あくまで「リクエスト時点」の情報しか見れないのでレスポンスのステータスコードによる振り分けはできません。

また、レスポンスによって制御するディレクティブも標準では存在しないようです。


mod_log_config - Apache HTTP Server

CustomLog ディレクティブではログをファイルではなくプログラムに渡すことができるので、

それを使用するのが一番現実的かと思います。


ざっくりとですが、標準の CommonLog 形式の場合、ステータスコード 200 をとりたければ、

CustomLog "| egrep 'HTTP/1.[01]\" 200' >> logs/success_log"

などとすればよいかと思います。(実際に試していないので、このまま動くかどうかはわかりませんが)

関連質問


●質問をもっと探す●



0.人力検索はてなトップ
8.このページを友達に紹介
9.このページの先頭へ
対応機種一覧
お問い合わせ
ヘルプ/お知らせ
ログイン
無料ユーザー登録
はてなトップ