5

将 Rails 从 3.1.2 升级到 4.0 后出现此错误。使用 rails s 启动我的服务器时,我遇到了以下错误

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 时出现错误的信息。

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

4

1 回答 1

6

该方法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

于 2013-09-20T16:51:20.640 回答