我收到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 }
}
答案 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。