【问题标题】:Ruby logging to several backends using Active Support logger使用 Active Support 记录器将 Ruby 记录到多个后端
【发布时间】:2014-12-04 16:53:46
【问题描述】:

我正在使用 Rails 3.2.12/Ruby 1.9.3 并尝试设置多个记录器,以便我可以将日志记录到文件和我们设置的 graylog 服务器。我已经接近使用这个解决方案,但使用 Gelf 记录器 - http://railsware.com/blog/2014/08/07/rails-logging-into-several-backends/

所以我已将ActiveSupport::Logger 移植回我的配置/初始化程序并如下设置gelf 记录器

(development.rb)

gelf_logger = GELF::Logger.new("greylogserver", 12201, "WAN", { :host => 'host', :facility => "railslog"})
Rails.logger.extend(ActiveSupport::Logger.broadcast(gelf_logger)) 

但是我发现我只会将错误记录到 graylog 服务器

ArgumentError: short_message is missing. Options version, short_message and host must be set.

当我调试代码时,我可以看到传递给 Gelf Logger add 方法(如下)的参数始终将第一个元素作为级别,第二个元素为零,第三个包含消息。这令人困惑,因为第二个参数应该是消息,第三个应该是程序名称。我想出的唯一解决方案是通过将第 6 行更改为使用 args[1] 作为消息来更改 Gelf-rb gem(如下所示),然后它可以工作,但这并不理想,必须有一种方法来修复这在我的代码中。

  def add(level, *args)
    raise ArgumentError.new('Wrong arguments.') unless (0..2).include?(args.count)

    # Ruby Logger's author is a maniac.
    message, progname = if args.count == 2
                          [args[1], args[1]]
                        elsif args.count == 0
                          [yield, default_options['facility']]
                        elsif block_given?
                          [yield, args[0]]
                        else
                          [args[0], default_options['facility']]
                        end
....

请注意,当我直接将 Rails 记录器设置为在 development.rb 中使用 Gelf 记录器时,它可以正常工作

Rails.logger = GELF::Logger.new("greylogserver", 12201, "WAN", { :host => 'host', :facility => "railslog"})

所以它必须与我对 ActiveSupport::Logger 的实现有关,它来自这里 - https://github.com/rails/rails/blob/6329d9fa8b2f86a178151be264cccdb805bfaaac/activesupport/lib/active_support/logger.rb

任何帮助将不胜感激

【问题讨论】:

  • 您是否将此作为 Gelf-rb gem 的问题提出来?我在尝试将 Graylog2 配置为 Rails 4.2 上的第二个日志记录后端时遇到了同样的问题。
  • 这看起来像一个相关问题:github.com/Graylog2/gelf-rb/issues/26

标签: ruby-on-rails-3 logging activesupport graylog2


【解决方案1】:

正如@Leons 提到的,与问题 #26 相同的问题已报告给项目。发帖人写了一个带有测试用例的补丁,并在 issue #27 中记录了一个拉取请求,其中包含一个修复以使 add 方法的接口与通常的定义相同。

它于 2014 年 12 月 22 日被合并。从那时起没有发布新版本。

我认为最好直接从 github repo 编译,例如:

$ echo "gem 'gelf', :git => 'https://github.com/Graylog2/gelf-rb.git'" >>Gemfile
$ bundle install

或类似的。

祝你好运。

【讨论】:

    猜你喜欢
    • 2019-11-03
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2012-04-18
    • 2015-07-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多