Hadoop Sqoop导入错误:不支持ClassVersionError CDH 5.16

Hadoop Sqoop导入错误:不支持ClassVersionError CDH 5.16,hadoop,hdfs,sqoop,cloudera,cloudera-cdh,Hadoop,Hdfs,Sqoop,Cloudera,Cloudera Cdh,我在rhel7系统上运行cdh5.16。我使用软件包安装了CDH 当我试图从位于远程服务器中的MySQL服务器运行Sqoop导入作业时,出现以下错误: Warning: /usr/lib/sqoop/../accumulo does not exist! Accumulo imports will fail. Please set $ACCUMULO_HOME to the root of your Accumulo installation. 19/06/03 18:39:43 INFO sq

我在
rhel7
系统上运行
cdh5.16
。我使用软件包安装了CDH

当我试图从位于远程服务器中的MySQL服务器运行
Sqoop
导入作业时,出现以下错误:

Warning: /usr/lib/sqoop/../accumulo does not exist! Accumulo imports will fail.
Please set $ACCUMULO_HOME to the root of your Accumulo installation.
19/06/03 18:39:43 INFO sqoop.Sqoop: Running Sqoop version: 1.4.6-cdh5.16.1
19/06/03 18:39:43 WARN tool.BaseSqoopTool: Setting your password on the command-line is insecure. Consider using -P instead.
19/06/03 18:39:43 INFO manager.MySQLManager: Preparing to use a MySQL streaming resultset.
19/06/03 18:39:43 INFO tool.CodeGenTool: Beginning code generation
Exception in thread "main" java.lang.UnsupportedClassVersionError: com/mysql/jdbc/Driver : Unsupported major.minor version 52.0
        at java.lang.ClassLoader.defineClass1(Native Method)
        at java.lang.ClassLoader.defineClass(ClassLoader.java:800)
        at java.security.SecureClassLoader.defineClass(SecureClassLoader.java:142)
        at java.net.URLClassLoader.defineClass(URLClassLoader.java:449)
        at java.net.URLClassLoader.access$100(URLClassLoader.java:71)
        at java.net.URLClassLoader$1.run(URLClassLoader.java:361)
        at java.net.URLClassLoader$1.run(URLClassLoader.java:355)
        at java.security.AccessController.doPrivileged(Native Method)
        at java.net.URLClassLoader.findClass(URLClassLoader.java:354)
        at java.lang.ClassLoader.loadClass(ClassLoader.java:425)
        at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:308)
        at java.lang.ClassLoader.loadClass(ClassLoader.java:358)
        at java.lang.Class.forName0(Native Method)
        at java.lang.Class.forName(Class.java:190)
        at org.apache.sqoop.manager.SqlManager.makeConnection(SqlManager.java:872)
        at org.apache.sqoop.manager.GenericJdbcManager.getConnection(GenericJdbcManager.java:52)
        at org.apache.sqoop.manager.SqlManager.execute(SqlManager.java:762)
        at org.apache.sqoop.manager.SqlManager.execute(SqlManager.java:785)
        at org.apache.sqoop.manager.SqlManager.getColumnInfoForRawQuery(SqlManager.java:288)
        at org.apache.sqoop.manager.SqlManager.getColumnTypesForRawQuery(SqlManager.java:259)
        at org.apache.sqoop.manager.SqlManager.getColumnTypes(SqlManager.java:245)
        at org.apache.sqoop.manager.ConnManager.getColumnTypes(ConnManager.java:333)
        at org.apache.sqoop.orm.ClassWriter.getColumnTypes(ClassWriter.java:1858)
        at org.apache.sqoop.orm.ClassWriter.generate(ClassWriter.java:1657)
        at org.apache.sqoop.tool.CodeGenTool.generateORM(CodeGenTool.java:106)
        at org.apache.sqoop.tool.ImportTool.importTable(ImportTool.java:494)
        at org.apache.sqoop.tool.ImportTool.run(ImportTool.java:621)
        at org.apache.sqoop.Sqoop.run(Sqoop.java:147)
        at org.apache.hadoop.util.ToolRunner.run(ToolRunner.java:70)
        at org.apache.sqoop.Sqoop.runSqoop(Sqoop.java:183)
        at org.apache.sqoop.Sqoop.runTool(Sqoop.java:234)
        at org.apache.sqoop.Sqoop.runTool(Sqoop.java:243)
        at org.apache.sqoop.Sqoop.main(Sqoop.java:252) 
这是我的sqoop导入语句:

sqoop导入--连接jdbc:mysql://10.188.177.228:3306/sales --用户名vaishak--密码root_123--表类别--m1--目标目录/user/hive/warehouse/sales.db/categories

我的java版本是:

openjdk version "1.8.0_212"
OpenJDK Runtime Environment (build 1.8.0_212-b04)
OpenJDK 64-Bit Server VM (build 25.212-b04, mixed mode)
这是在Cloudera manager安装期间安装的java

我浏览了下面的stackoverflow链接,在这种情况下没有多大帮助:

在CDH之前,我已经分别安装了Hadoop版本3和sqoop(在CDH之外),并且能够成功地运行sqoop脚本

但我无法在这里找到问题所在。我也无法找到
HADOOP\u前缀
JAVA\u HOME
路径

在开始import语句之前,我已经下载了mysql-connector
mysql-connector-java-8.0.13.jar
并将其放置在
/usr/lib/sqoop/lib
路径中


我对设置Hadoop组件很陌生,尤其是使用CDH。

发现了这个问题!。似乎安装了两个版本的java。我删除了旧版本的java,现在一切都开始工作了

错误是不支持Java 8。严格来说,与Hadoop或Sqoop无关。您可能需要验证CDH 5.16使用的Java版本。根据cloudera文档,5.16及更高版本支持Java 8.cloudera链接:。这也是我感到困惑的原因。CDH支持Java版本。不确定为什么现在会出现此错误。@cricket\u 007您认为此错误与使用的sql连接器有关吗?这是可能的。如果您使用的驱动程序仅适用于Java7,我会感到惊讶,尽管这不是驱动程序的问题。该驱动程序支持Java1.8。现在无法找出导致此问题的原因。。。