我正在使用logstash-1.5.2和mongodb 3.0.4。我正在尝试使用以下配置启动logstash,该配置无效。
input{
stdin{
}
}
output {
mongodb {
database => "logdb"
collection => "plain"
uri => "mongodb://localhost:27017"
} }
我面对的是错误的错误:
报告的错误是: 未初始化的常量Mongo :: URIParser
请帮忙。
答案 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设置中遇到过这个问题。每次换线都对我有用。