侧边栏壁纸
博主头像
极客日记 博主等级

行动起来,活在当下

  • 累计撰写 93 篇文章
  • 累计创建 17 个标签
  • 累计收到 1 条评论

目 录CONTENT

文章目录

【Ruby on Rails】日志工具log4r

Jack.Jia
2022-03-26 / 0 评论 / 0 点赞 / 5 阅读 / 0 字

日志: log4r

日志是我们调试的最重要的手段,没有之一。

我们可以通过 debug, 断点来人肉找到问题,但是如果没有把信息保存到文件中,就无法 事后找到线索。

最好的日志应该是 每日分卷, 有时间戳,可以控制输入级别。

在 ruby 中,虽然有自带的 logger, 但是跟 log4r 还是有很大距离的。也很麻烦。

所以,就出现了 log4r (log for ruby).

使用步骤

  1. 新建一个 log4r 的配置文件: config/log4r.yml

log4r_config:

 # define all loggers ...
  loggers:
    - name      : production
      level     : WARN
      trace     : 'false'
      outputters :
      - datefile
    - name      : development
      level     : DEBUG
      trace     : 'true'
      outputters :
      - datefile

  # define all outputters (incl. formatters)
  outputters:
  - type: DateFileOutputter
    name: datefile
    dirname: "log"
    filename: "my_app.log" # notice the file extension is needed!
    formatter:
      date_pattern: '%H:%M:%S'
      pattern     : '%d %l: %m '
      type        : PatternFormatter
  1. 修改 config/application.rb
require 'rails/all'
# add these line for log4r
require 'log4r'
require 'log4r/yamlconfigurator'
require 'log4r/outputter/datefileoutputter'
include Log4r

Bundler.require(:default, Rails.env) if defined?(Bundler)
module Zurich
  class Application < Rails::Application
    #...
    # assign log4r's logger as rails' logger.
    log4r_config= YAML.load_file(File.join(File.dirname(__FILE__),"log4r.yml"))
    YamlConfigurator.decode_yaml( log4r_config['log4r_config'] )
    config.logger = Log4r::Logger[Rails.env]
  end
end
  1. 修改 Gemfile, 增加 log4r 的配置. 注意版本不能低于 1.1.9. 否则不支持每日分卷
gem 'log4r', '1.1.9'
  1. 如果你用的是 Rails4, 那么需要增加下面这个文件
# config/initializers/log4r_patch_for_rails4.rb
class Log4r::Logger
  def formatter()
  end
end

现在就可以了。 进入到你的 Rails.root, 重启 rails, 就会发现 log 目录开始分卷了。

May  9 17:05 rails_2011-05-09.log
May 10 13:42 rails_2011-05-10.log

日志的内容看起来如下:

$ tail log/rails_2011-05-10.log

Started GET "/????_settings/19/edit" for 127.0.0.1 at ...
13:42:11 INFO:   Processing by ????SettingsController ...
13:42:11 INFO:   Parameters: {"id"=>"19"}
13:42:12 DEBUG:   ????Setting Load (0.0ms)  SELECT "d ...
13:42:12 INFO: Completed 200 OK in 750ms
0

评论区