无法使用mongoDB配置启动logstash?

时间:2015-07-27 11:55:16

标签: mongodb logstash

我正在使用logstash-1.5.2和mongodb 3.0.4。我正在尝试使用以下配置启动logstash,该配置无效。

input{
    stdin{
    }
}

output {
  mongodb {
    database => "logdb"    
    collection => "plain" 
    uri => "mongodb://localhost:27017" 
  } }

我面对的是错误的错误:

./ logstash -f conf / mongo.conf

报告的错误是:   未初始化的常量Mongo :: URIParser

请帮忙。

1 个答案:

答案 0 :(得分:0)

问题是由最新版本的logstash-output-mongodb中的错误引起的。请参阅issue reported on github。可以通过更改mongodb插件中的几行来修复它。 (请注意,因为这是一个既不支持身份验证也不支持远程服务器的hacky解决方案。)

按照提到的here更改mongo.rb文件的行。 (路径应该类似于/opt/logstash/vendor/bundle/jruby/1.9/gems/logstash-output-mongodb-0.1.4/lib/logstash/outputs/mongodb.rb您可以在错误消息中找到确切的路径。)

替换:

    uriParsed=Mongo::URIParser.new(@uri)
    conn = uriParsed.connection({})
    if uriParsed.auths.length > 0
      uriParsed.auths.each do |auth|
        if !auth['db_name'].nil?
          conn.add_auth(auth['db_name'], auth['username'], auth['password'], nil)
        end 
      end
      conn.apply_saved_authentication()
    end
    @db = conn.db(@database)

由:

    client = Mongo::Client.new([ '127.0.0.1:27017' ])
    @db = client.use(@database)

并替换:

@db.collection(event.sprintf(@collection)).insert(document)

由:

@db.database.collection(event.sprintf(@collection)).insert_one(document)

我自己在几个logstash设置中遇到过这个问题。每次换线都对我有用。