com.mysql.jdbc.Driver未加载。您确定在:jdbc_driver_library中包含正确的jdbc驱动程序

时间:2019-06-20 09:22:51

标签: java mysql logstash elastic-stack

我收到Logstash的Java版本和mysql-connect-java.jar兼容性问题。

谁能告诉我哪个版本的mysql-connect-java.jar与哪个版本的Java兼容?

错误:

com.mysql.cj.jdbc.Driver not loaded. Are you sure you've included the correct jdbc driver in :jdbc_driver_library?

我当前的Java版本是

openjdk version "1.8.0_212"
OpenJDK Runtime Environment (build 1.8.0_212-8u212-b03-0ubuntu1.16.04.1-b03)
OpenJDK 64-Bit Server VM (build 25.212-b03, mixed mode)

我尝试使用下面的mysql连接器jar文件,但每个失败。

mysql-connector-java-8.0.16.jar
mysql-connector-java-8.0.15.jar
mysql-connector-java-6.0.5.jar
mysql-connector-java-5.1.46.jar
mysql-connector-java-5.1.4.jar

Logstash配置文件是mysql.conf

input {
    jdbc {
        jdbc_connection_string => "jdbc:mysql://localhost:3306/prbi"
        jdbc_user => "root"
        jdbc_password => ""
        jdbc_driver_library => "mysql-connector-java-8.0.15.jar" #tried above every jar
        jdbc_driver_class => "com.mysql.cj.jdbc.Driver" #tried com.mysql.jdbc.Driver too
        schedule => "* * * * *"
        use_column_value => true
        tracking_column => "%{id}"
        clean_run => true
        statement => "SELECT * from tmp_j_summaryrepor"
    }
}
output {
    elasticsearch {
    hosts => ['http://localhost:9200']
    index => "prsummaryreport"
    document_type => "prsummaryreport"
    document_id => "%{id}" # It is a Primary Key of table
    }
    stdout { codec => json_lines } 
}

3 个答案:

答案 0 :(得分:8)

对于logstash 6.2.x及更高版本,更喜欢在以下位置添加驱动程序:

/usr/share/logstash/logstash-core/lib/jars/

,而是保留jdbc_driver_library为空。许多elastic.co论坛也都引用了这一点。

答案 1 :(得分:1)

Logstash无法加载驱动程序,因为它在错误的位置寻找驱动程序,您应始终指定驱动程序的完整路径,例如:

jdbc_driver_library => "/opt/drivers/mysql-connector-java-8.0.15.jar"

答案 2 :(得分:0)

就我而言,我将jdbc_driver_library的完整路径指定为:"/opt/drivers/mysql-connector-java-8.0.15.jar"

它在重新启动之前一直在工作,然后突然开始抛出错误。

我发现由于某种原因jdbc.jar文件已损坏,文件大小已更改为 0KB 。我重新下载了Jar,将其放在完整路径中,然后重新启动。

因此,您可能只想检查jdbc文件是否正常。不能为0KB。