Warning: file_get_contents(/data/phpspider/zhask/data//catemap/8/logging/2.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Ruby on rails 3 使用Active Support logger将Ruby日志记录到多个后端_Ruby On Rails 3_Logging_Activesupport_Graylog2 - Fatal编程技术网

Ruby on rails 3 使用Active Support logger将Ruby日志记录到多个后端

Ruby on rails 3 使用Active Support logger将Ruby日志记录到多个后端,ruby-on-rails-3,logging,activesupport,graylog2,Ruby On Rails 3,Logging,Activesupport,Graylog2,我使用的是Rails 3.2.12/Ruby 1.9.3,我正在尝试设置多个记录器,这样我就可以同时记录到一个文件和一个我们已经设置好的graylog服务器。我已接近使用此解决方案,但使用了Gelf记录器- 因此,我已将ActiveSupport::Logger向后移植到我的配置/初始化程序中,并按如下方式设置了gelf记录器 (development.rb) gelf_logger = GELF::Logger.new("greylogserver", 12201, "WAN", { :ho

我使用的是Rails 3.2.12/Ruby 1.9.3,我正在尝试设置多个记录器,这样我就可以同时记录到一个文件和一个我们已经设置好的graylog服务器。我已接近使用此解决方案,但使用了Gelf记录器-

因此,我已将
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记录器
add
方法(如下)中,它总是将第一个元素作为级别,第二个元素为nil,第三个元素包含消息。这是令人困惑的,因为第二个参数应该是消息,第三个是程序名。我提出的唯一解决方案是修改Gelf rb gem(如下所示),将第6行更改为使用args[1]作为消息,然后它就可以工作了,但是这并不理想,必须有一种方法在我的代码中解决这个问题

  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 logger时,它工作正常

Rails.logger = GELF::Logger.new("greylogserver", 12201, "WAN", { :host => 'host', :facility => "railslog"})
因此,这与我的
ActiveSupport::Logger
实现有关,从这里开始-


任何帮助都将不胜感激,

因为@Leons提到了与第26期相同的问题,并向项目报告了该问题。海报上写了一个带有测试用例的补丁,并登录了一个带有补丁的pull请求,以使add方法的接口与通常的定义相同

该公司于2014年12月22日合并。从那时起,没有发布新版本

我认为最好直接从github repo编译,如下所示:

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


祝您好运。

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