我正在使用 Rails 3.2.12/Ruby 1.9.3,并尝试设置多个记录器,以便我可以记录到文件和我们设置的灰色日志服务器。我已经接近使用这个解决方案,但使用凝胶记录器 - 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))
但是我发现我只收到记录到灰色日志服务器的错误
ArgumentError: short_message is missing. Options version, short_message and host must be set.
当我调试代码时,我可以看到参数被传递到 Gelf Logger add
方法(如下(始终将第一个元素作为级别,第二个元素为 nil,第三个元素包含消息。这令人困惑,因为第二个参数应该是消息,第三个参数应该是 progname。我想出的唯一解决方案是通过更改第 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
任何帮助将不胜感激
正如@Leons所提到的,同样的问题被报告给项目作为问题#26。海报编写了一个带有测试用例的补丁,并在问题 #27 中记录了一个带有修复的拉取请求,以使 add 方法的接口与通常的定义相同。
这于2014年12月22日合并。从那以后,没有发布新版本。
我认为最好直接从 github 存储库编译
,如下所示:$ echo "gem 'gelf', :git => 'https://github.com/Graylog2/gelf-rb.git'" >>Gemfile
$ bundle install
或类似。
祝你好运。