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

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

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

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

Ruby on Rails

Ruby on Railsは、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

Q&A

解決済

1回答

2505閲覧

Railsで複数のログファイルをローテートする方法

退会済みユーザー

退会済みユーザー

総合スコア0

logrotate

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

Ruby on Rails

Ruby on Railsは、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

0グッド

0クリップ

投稿2018/07/08 08:05

編集2018/07/26 00:00

Ruby on Rails上で複数のログファイルをローテートするための設定方法はありますか。
一つのログファイルならば以下のように書くことでローテートできました。

ruby

1config.logger = Logger.new('log/rails.log', 5, 10 * 1024 * 1024)

しかしrails.logの他にunicorn.logがあり、そのログファイルもローテートする設定が書けません。以下のようにすると当然ですがunicorn.logのみがローテートされます。

ruby

1config.logger = Logger.new('log/rails.log', 5, 10 * 1024 * 1024) 2config.logger = Logger.new('log/unicorn.log', 5, 10 * 1024 * 1024)

Railsの外でcronでローテートすれば問題はありませんが、Railsの設定内で複数のファイルをローテートするようにできないのでしょうか。

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

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

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

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

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

takumiabe

2018/07/10 02:00 編集

そもそも、loggerに2度代入しているので、片方しか有効にならないのですよね。 rotationとは関係なく、「複数のログを出力する方法」を調べるべきな気がしますが、相違ないでしょうか。
退会済みユーザー

退会済みユーザー

2018/07/10 03:17

情報が不足しており申し訳ございません。複数のログはすでに出力できています。sidekiqとunicornとRailsです。それらをRails上で一括してローテーションできないか、ということです。
guest

回答1

0

ベストアンサー

残念ながら、Unicornにはそのような設定はありません。

unicornの公式サイトのREADMEにはこう書かれています。

Builtin reopening of all log files in your application via USR1 signal. This allows logrotate to rotate files atomically and quickly via rename instead of the racy and slow copytruncate method. unicorn also takes steps to ensure multi-line log entries from one request all stay within the same file.

logrotateなどで、リネームしてからUSR1シグナルを使え、ということですね。
おそらく、Unicornの作者として、ログがロストされず確実に出力できるローテートの方法がこれだったということではないかと思います。
もちろん、RailsとWhenever等で定期的にrenameとUSR1シグナルを飛ばす仕組みも作ろうと思えばできるかと思いますが、普通にlogrotateを使った方が確実そうです。

ちなみにlogrotateを使ってローテートさせるための設定サンプルは公式でも配布しています。

http://repo.or.cz/unicorn.git/blob/HEAD:/examples/logrotate.conf

投稿2018/07/25 13:33

takahashim

総合スコア1877

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

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

退会済みユーザー

退会済みユーザー

2018/07/25 13:45

ご回答ありがとうございます。まさかtakahashimさんよりご回答頂けるとは思っておりませんでした。ご活躍をいつも拝見しております。 さて、回答内容について承知いたしました。詳しい付記もいただきありがとうございます。もやもやしていたものが晴れました。今後の開発の参考にさせていただきたいと思います。
takahashim

2018/07/25 14:47

ひー、そう言っていただけると恐縮です。いや、正直unicornはそんなに詳しい訳でもないですし…ともあれ参考になれば幸いです。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問