首页 > 解决方案 > 使用 Logstash 将数据从 Postgres 导出到 ElasticSearch 给出 LoadError: no such file to load -- pg

问题描述

我正在尝试使用 Logstash 将数据从 Postgres 导出到 ElasticSearch。

这是我的 conf 文件,位于路径“ /etc/logstash/conf.d

input {
    jdbc {
        jdbc_connection_string => "postgresql://localhost:5432/panzura"
        jdbc_user => "panzura"
    jdbc_password => "*******"
    jdbc_driver_library => "/etc/logstash/jdbc-drivers/postgresql-42.2.9.jar"
        jdbc_validate_connection => true
        jdbc_driver_class => "org.postgresql.Driver"
        statement => "SELECT * from file"
    }
}

filter { }


output {
    elasticsearch {
        index => "files"
        document_id => "%{id}"
        hosts => "https://vzfnrf9q3fagdht05b:xw32qdcnr4w2zgss@es.vizion.ai:443"
    }
}

现在,我正在尝试使用以下命令运行 logstash:

/usr/share/logstash/bin/logstash -f /etc/logstash/conf.d/pg-to-elastic.conf

但我收到以下错误:

[ERROR] 2019-12-28 14:50:38.339 [[main]<jdbc] jdbc - Unable to connect to database. Tried 1 times {:error_message=>"LoadError: no such file to load -- pg"}
[ERROR] 2019-12-28 14:50:38.361 [[main]<jdbc] javapipeline - A plugin had an unrecoverable error. Will restart this plugin.
  Pipeline_id:main
  Plugin: <LogStash::Inputs::Jdbc jdbc_user=>"panzura", jdbc_validate_connection=>true, jdbc_password=><password>, statement=>"SELECT * from file", jdbc_driver_library=>"/etc/logstash/jdbc-drivers/postgresql-42.2.9.jar", jdbc_connection_string=>"postgresql://localhost:5432/panzura", id=>"07d4c82d79b5f028b0563465cafb72e0dfbc5833c51be9658f8dd516f69a0fbf", jdbc_driver_class=>"org.postgresql.Driver", enable_metric=>true, codec=><LogStash::Codecs::Plain id=>"plain_d31ea3e3-207b-41c3-9593-f2139bdb2b55", enable_metric=>true, charset=>"UTF-8">, jdbc_paging_enabled=>false, jdbc_page_size=>100000, jdbc_validation_timeout=>3600, jdbc_pool_timeout=>5, sql_log_level=>"info", connection_retry_attempts=>1, connection_retry_attempts_wait_time=>0.5, plugin_timezone=>"utc", last_run_metadata_path=>"/home/alcanzar/.logstash_jdbc_last_run", use_column_value=>false, tracking_column_type=>"numeric", clean_run=>false, record_last_run=>true, lowercase_column_names=>true, use_prepared_statements=>false>
  Error: LoadError: no such file to load -- pg
  Exception: Sequel::AdapterNotFound
  Stack: org/jruby/RubyKernel.java:987:in `require'
/usr/share/logstash/vendor/bundle/jruby/2.5.0/gems/polyglot-0.3.5/lib/polyglot.rb:65:in `require'
/usr/share/logstash/vendor/bundle/jruby/2.5.0/gems/sequel-5.27.0/lib/sequel/adapters/postgres.rb:6:in `<main>'
org/jruby/RubyKernel.java:987:in `require'
org/jruby/RubyKernel.java:1015:in `require_relative'
/usr/share/logstash/vendor/bundle/jruby/2.5.0/gems/sequel-5.27.0/lib/sequel/adapters/postgresql.rb:1:in `<main>'
org/jruby/RubyKernel.java:987:in `require'
/usr/share/logstash/vendor/bundle/jruby/2.5.0/gems/polyglot-0.3.5/lib/polyglot.rb:65:in `require'
/usr/share/logstash/vendor/bundle/jruby/2.5.0/gems/sequel-5.27.0/lib/sequel/database/connecting.rb:88:in `load_adapter'
/usr/share/logstash/vendor/bundle/jruby/2.5.0/gems/sequel-5.27.0/lib/sequel/database/connecting.rb:17:in `adapter_class'
/usr/share/logstash/vendor/bundle/jruby/2.5.0/gems/sequel-5.27.0/lib/sequel/database/connecting.rb:36:in `connect'
/usr/share/logstash/vendor/bundle/jruby/2.5.0/gems/sequel-5.27.0/lib/sequel/core.rb:121:in `connect'
/usr/share/logstash/vendor/bundle/jruby/2.5.0/gems/logstash-input-jdbc-4.3.19/lib/logstash/plugin_mixins/jdbc/jdbc.rb:120:in `block in jdbc_connect'
org/jruby/RubyKernel.java:1425:in `loop'
/usr/share/logstash/vendor/bundle/jruby/2.5.0/gems/logstash-input-jdbc-4.3.19/lib/logstash/plugin_mixins/jdbc/jdbc.rb:117:in `jdbc_connect'
/usr/share/logstash/vendor/bundle/jruby/2.5.0/gems/logstash-input-jdbc-4.3.19/lib/logstash/plugin_mixins/jdbc/jdbc.rb:184:in `open_jdbc_connection'
/usr/share/logstash/vendor/bundle/jruby/2.5.0/gems/logstash-input-jdbc-4.3.19/lib/logstash/plugin_mixins/jdbc/jdbc.rb:243:in `execute_statement'
/usr/share/logstash/vendor/bundle/jruby/2.5.0/gems/logstash-input-jdbc-4.3.19/lib/logstash/inputs/jdbc.rb:309:in `execute_query'
/usr/share/logstash/vendor/bundle/jruby/2.5.0/gems/logstash-input-jdbc-4.3.19/lib/logstash/inputs/jdbc.rb:281:in `run'
/usr/share/logstash/logstash-core/lib/logstash/java_pipeline.rb:322:in `inputworker'
/usr/share/logstash/logstash-core/lib/logstash/java_pipeline.rb:314:in `block in start_input'
...
...

如果我们专注于第一行,它会说:

Unable to connect to database. Tried 1 times {:error_message=>"LoadError: no such file to load -- pg"}

我无法解决这个问题。

标签: logstashelastic-stacklogstash-jdbc

解决方案


我有同样的问题!我试图找到两天的解决方案。我只是通过授予所有用户对 pipeline.conf 文件的读和写权限(我使用的是 Mac OS)来解决它,而不是写:“Users/user/Desktop/postgresql-42.2.9.jar”,而是写:“ ~/Desktop/postgresql-42.2.9.jar"


推荐阅读