0

我正在使用 RoR 4.1.12 和 log4r gem 来格式化日志。我以为一切都好,但是如果我想更改日志级别,它根本没有影响。

我有以下内容config/log4r_init.rb

require 'log4r'
require 'log4r/yamlconfigurator'
require 'log4r/outputter/fileoutputter'
require 'log4r/outputter/datefileoutputter'

# The problem is that Rails 4.2 (not sure about other versions at the moment) expects a method
# on the logger called formatter(). Log4r, however, defines formatter() on each outputter of 
# the logger (i.e. so that each outputter can have a different format). 
# We could monkey-patch it like this
Log4r::Logger.class_eval do
  def formatter
    # Give it the first formatter we have?
    outputters[0].formatter if outputters.any?
  end
end

# log4r.yml configuration is expected to be in the same directory as this file. 
log4r_config = YAML.load(ERB.new(File.read(File.expand_path(File.dirname(__FILE__) + "/log4r.yml"))).result)
Log4r::YamlConfigurator.decode_yaml(log4r_config['log4r_config'])

V2p0::Application.config.logger = Log4r::Logger[Rails.env]

以及以下内容config/log4r.yml

log4r_config:
  loggers:
    - name : development
      level : WARN
      additive : 'false'
      trace : 'true'
      outputters:
      - standard_plus_trace_log_outputter
      - stderr_outputter
    - name : test
      level : DEBUG
      additive : 'false'
      trace : 'true'
      outputters:
      - standard_plus_trace_log_outputter
    - name : staging
      level : INFO
      additive : 'false'
      trace : 'true'
      outputters:
      - standard_plus_trace_log_outputter
      - stderr_outputter
    - name : production
      level : INFO
      additive : 'false'
      trace : 'true'
      outputters:
      - standard_plus_trace_log_outputter
      - stderr_outputter

  outputters:
    - type : StderrOutputter
     name : stderr_outputter
      level : INFO
      formatter:
        date_pattern: '%Y-%m-%d %H:%M:%S'
        pattern : "[SXS] [%d] PID:%p %t %l %m"
        type : PatternFormatter
    - type : FileOutputter
      name : standard_log_outputter
      trunc : 'false'
      filename : <%= "#{Rails.root}/log/#{Rails.env}.log" %>
      formatter :
        date_pattern: '%Y-%m-%d %H:%M:%S.%3N'
        pattern : "[SXS] [%d] %l %m"
        type : PatternFormatter
    - type : FileOutputter
      name : standard_plus_trace_log_outputter
      trunc : 'false'
      filename : <%= "#{Rails.root}/log/#{Rails.env}.log" %>
      formatter :
        date_pattern: '%Y-%m-%d %H:%M:%S.%3N'
        pattern : "[SXS] [%d] %t %l %m"
        type : PatternFormatter

即使在开发模式下级别是 WARN,我在错误输出中看到很多类似的日志消息:

[SXS] [2017-12-19 14:11:32] PID:947 /home/ntibor/.bundle/ruby/2.2.0/rails-9bfb9f2c3b8b/activesupport/lib/active_support/log_subscriber.rb:93:in `info' INFO   Rendered shared/_common_scripts.html.erb (5.6ms)

怎么了?

4

0 回答 0