Logger::Formatterを拡張したクラスを作って、各設定ファイルでそれをformatterとして指定すると最低限の追加でよくなる。
拡張したformatterは以下のように書く。
extras/logger/formatter_with_time.rb
# coding:utf-8
class Logger::FormatterWithTime < Logger::Formatter
cattr_accessor(:datetime_format) { "%Y-%m-%d %H:%M:%S" }
# 出力フォーマットの定義。ここはお好きに。
def call(severity, timestamp, progname, msg)
%![#{timestamp.strftime(datetime_format)}] [#{severity.downcase}] #{msg}\n!
end
end
extrasの下がautoloadになるように config/application.rbのautoloadの設定をオン(デフォルトではコメントアウトされている)にしておく。
config/environments/development.rb に下記のように追加。
#
# ログフォーマットの変更
#
config.logger = Logger.new("log/development.log")
config.logger.formatter = Logger::FormatterWithTime.new
Railsを再起動すると、下記のようにログにタイムスタンプがかかれて見やすくなった。ログレベルは小文字の方がログが見やすくなっていい。
[2014-03-24 00:22:23] [info]
[2014-03-24 00:22:23] [info] Started GET "/assets/logo.png" for 123.220.144.68 at 2014-03-24 00:22:23 +0900
[2014-03-24 00:22:24] [info] Served asset /logo.png - 304 Not Modified (0ms)