RAILS 4.0中Log4r的未定义方法格式化程序

将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 # (NoMethodError) 

我一直在Log4r网站上,但没有任何信息;有关升级Rails时的错误。

有谁知道这个bug来自哪里。 谢谢!

方法formatter未在Log4r::Logger上定义,而是在Log4r::FileOutputterLog4r::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等新文件中