2014年3月24日月曜日

【RoR】Loggerのフォーマットを指定する。

 RoRのデフォルトのloggerはタイムスタンプもでないので見づらい。出力のフォーマットをカスタマイズして見やすくするには、config/environments/#{env名}.rb にfommaterを定義して直接渡してもいいが、各envの設定ファイルで記載がいるので冗長になる。
 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)

0 件のコメント:

コメントを投稿