質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.50%
Apache

Apacheは、Apache HTTP Serverの略で、最も人気の高いWebサーバソフトウェアの一つです。安定性が高いオープンソースソフトウェアとして商用サイトから自宅サーバまで、多くのプラットフォーム向けに開発・配布されています。サーバーソフトウェアの不具合(NCSA httpd)を修正するパッチ(a patch)を集積、一つ独立したソフトウェアとして開発されました。

Q&A

解決済

1回答

442閲覧

apache CustomLog の設定について。

EzrealTrueshot

総合スコア388

Apache

Apacheは、Apache HTTP Serverの略で、最も人気の高いWebサーバソフトウェアの一つです。安定性が高いオープンソースソフトウェアとして商用サイトから自宅サーバまで、多くのプラットフォーム向けに開発・配布されています。サーバーソフトウェアの不具合(NCSA httpd)を修正するパッチ(a patch)を集積、一つ独立したソフトウェアとして開発されました。

0グッド

0クリップ

投稿2017/10/19 10:51

apacheでlogの名前を以下のようにしたいです。

[unixtime秒 / 600秒](←計算した結果)_hoge.log

アクセスがある度に、logファイルが出来上がっていくイメージです。

正確には、
アクセスがある度に、そのアクセスのあった時間(unixtime秒を600秒で割った結果)を名前に含むlogファイルがどんどん出来上がっていくイメージです。


apacheのlogファイル名を動的に作成する方法がありましたら教えて頂けませんでしょうか?

■環境
Ubuntu 16.04
Apache 2.4

何か足りない情報等ございましたら追記させて頂きます。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

Apache httpd に含まれる rotatelogs を使うといいと思います。
コマンドやログファイルのパスは Ubuntu に合わせて変更ください。

CustomLog "|/usr/sbin/rotatelogs -l -f -c -p /usr/local/bin/rename_rotatelogs.sh /var/log/httpd/%s_orig.log 600" common

600秒ごとに「UNIX時間_orig.log」ファイルが作成されます。
その際、-p オプションで指定したプログラムが、引数1=新しいログファイル名引数2=古いログファイル名 (ともに絶対パス)で実行されますので、古いログファイルをリネームするといいと思います。
※新しいログファイルをリネームすると、restart で直近のログが消えてしまいます。

プログラムは、ファイル名から UNIX時間を抽出して、600 で割って、リネーム後のファイル名を組み立てて、mv コマンドでリネームするよう、シェルスクリプトなどで作成ください。

投稿2017/10/19 14:02

編集2017/10/19 14:48
TaichiYanagiya

総合スコア12141

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

EzrealTrueshot

2017/10/23 03:23

ありがとうございます! 参考にさせて頂き、無事に実装できました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.50%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問