将Rails从3.1.2升级到4.0后,我收到此错误。当使用rails启动我的服务器时,我遇到了以下错误
C:/ruby-2.0.0/lib/ruby/gems/2.0.0/gems/railties-4.0.0/lib/rails/commands/server.rb:78:in `start': undefined method `formatter' for #<Log4r::Logger:0x26dd908> (NoMethodError)
我一直在Log4r网站上但没有任何信息;有关升级Rails时出现的错误信息。
有没有人知道这个bug来自哪里。谢谢!
答案 0 :(得分:5)
方法formatter
未在Log4r::Logger
上定义,而是在Log4r::FileOutputter
上定义。因此,我很惊讶在Rails更新之前工作。也许在不同版本的Log4r之间发生了变化。
请尝试以下方法(使用经过调整的文件名和模式):
require 'log4r'
outputter = Log4r::FileOutputter.new('log4r', filename: 'foobar.log')
outputter.formatter = Log4r::PatternFormatter.new(
date_pattern: "%FT%T.000Z", pattern: "%d [%l] %m"
)
logger = Log4r::Logger.new('log4r')
logger.outputters = [outputter]
将此代码添加到config/application.rb
或新文件,例如config/initializers/logger.rb