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

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

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

logrotateはログの世代管理やサイズ制限を行うLinux標準のツールです。

cron

cronは、Unix系OS上でデーモンプロセスとして動作する、スクリプトの自動実行が可能なジョブスケジューラです。

Linux

Linuxは、Unixをベースにして開発されたオペレーティングシステムです。日本では「リナックス」と呼ばれています。 主にWebサーバやDNSサーバ、イントラネットなどのサーバ用OSとして利用されています。 上位500のスーパーコンピュータの90%以上はLinuxを使用しています。 携帯端末用のプラットフォームAndroidは、Linuxカーネル上に構築されています。

Ubuntu

Ubuntuは、Debian GNU/Linuxを基盤としたフリーのオペレーティングシステムです。

Q&A

解決済

1回答

5199閲覧

ログローテートの実行がうまくいかない

ruuuu

総合スコア168

logrotate

logrotateはログの世代管理やサイズ制限を行うLinux標準のツールです。

cron

cronは、Unix系OS上でデーモンプロセスとして動作する、スクリプトの自動実行が可能なジョブスケジューラです。

Linux

Linuxは、Unixをベースにして開発されたオペレーティングシステムです。日本では「リナックス」と呼ばれています。 主にWebサーバやDNSサーバ、イントラネットなどのサーバ用OSとして利用されています。 上位500のスーパーコンピュータの90%以上はLinuxを使用しています。 携帯端末用のプラットフォームAndroidは、Linuxカーネル上に構築されています。

Ubuntu

Ubuntuは、Debian GNU/Linuxを基盤としたフリーのオペレーティングシステムです。

0グッド

1クリップ

投稿2020/06/02 23:46

編集2020/06/02 23:57

logrotateにより、logの管理を行おうと考えているのですが、logrotate.confファイルに設定したディレクトリが読み込まれません。
ログローテートはQiitaの記事を参考にいたしました。
以下は、/tmp/log/logrotate.confファイルとなります。

/var/www/django/app/app_test/app_project/test/log { missingok rotate 1 dateext dateformat _%Y%m%d compress }

「/usr/sbin/logrotate -d /tmp/log/logrotate.conf」こちらのコマンドを実行したのですが、以下のような結果になってしまいました。

sbin/logrotate -d /tmp/log/logrotate.conf reading config file /tmp/log/logrotate.conf Reading state from file: /var/lib/logrotate/status Allocating hash table for state file, size 64 entries Creating new state Creating new state Creating new state Creating new state Creating new state Creating new state Creating new state Creating new state Creating new state Creating new state Creating new state Creating new state Creating new state Creating new state Creating new state Creating new state Creating new state Creating new state Creating new state Creating new state Creating new state Creating new state Creating new state Creating new state Creating new state Creating new state Creating new state Creating new state Creating new state Creating new state Creating new state Creating new state Creating new state Creating new state Creating new state Handling 1 logs rotating pattern: /var/www/django/app/app_test/app_project/test/log 1048576 bytes (1 rotations) empty log files are rotated, old logs are removed No logs found. Rotation not needed.

しかし、/var/www/django/app/app_test/app_project/test/logフォルダ下には、「20200601_130001.log」といったファイルが数十個保存されています。
何故、「empty log files are rotated, old logs are removed」こちらの結果となってしまうのかが分かりません。ログファイルが認識されない理由につきまして、どなたかご助言頂けましたら幸いです。

追記です
Qiitaの記事の通り、「/usr/sbin/logrotate -d /tmp/log/logrotate.conf」を以下のようにして試してみた場合ですが、「/tmp/log/httpd/access_log」こちらのフォルダは認識がされているようです。

/tmp/log/httpd/access_log { missingok rotate 1 dateext dateformat _%Y%m%d compress }

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

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

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

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

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

guest

回答1

0

ベストアンサー

logrotate.confファイルに設定したディレクトリが読み込まれません。

logrotate.confに書くのはディレクトリ名ではなくファイル名ですよ。
/var/www/django/app/app_test/app_project/test/logディレクトリ内の拡張子がlogのファイルをすべて対象にするなら

/var/www/django/app/app_test/app_project/test/log/*.log { (略) }

です。

投稿2020/06/03 00:37

SHOMI

総合スコア4079

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

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

ruuuu

2020/06/03 02:22

ご回答ありがとうございます。 ログローテートは、基本的に大量のログファイルを入れ替える為に使用するものであると認識していたのですが、Qiita記事などでは、特定のファイル「/tmp/log/httpd/access_log 」を指定しています。 これには、何か理由があったりするのでしょうか?
SHOMI

2020/06/03 05:13 編集

わかりやすいからじゃないですか?記事を書いた人に聞いてください。 $ man logrotate manコマンドで確認すれば複数ファイルの例も書いてありますよ。 https://linux.die.net/man/8/logrotate
ruuuu

2020/06/03 05:15

記事書いた人でないと分からないですよね...ログローテートについて少々混乱してしまっていました...
ruuuu

2020/06/03 05:15

しかし、大分調べていく過程で分かってきました。 ありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問