Java mysql中的配置单元Metatstore(通过jdbc)失败-NoClassDefFoundError JdbcUriParseException

Java mysql中的配置单元Metatstore(通过jdbc)失败-NoClassDefFoundError JdbcUriParseException,java,mysql,jdbc,hive,jar,Java,Mysql,Jdbc,Hive,Jar,问题摘要 试图将工作配置单元安装连接到运行正常的mysql数据库以创建hcatalog(又名metastore) 已经按照规定配置了hive-site.xml,并且每个线程都使用Java 8 确认用于配置单元交互的Bash cli user@node:hive Hive Session ID = 66da2903-6e11-43e6-95de-84bf41b1b977 Logging initialized using configuration in jar:file:/home/hadoo

问题摘要 试图将工作配置单元安装连接到运行正常的mysql数据库以创建hcatalog(又名metastore) 已经按照规定配置了hive-site.xml,并且每个线程都使用Java 8

确认用于配置单元交互的Bash cli

user@node:hive
Hive Session ID = 66da2903-6e11-43e6-95de-84bf41b1b977

Logging initialized using configuration in jar:file:/home/hadoop/apache-hive-3.1.2-bin/lib/hive-common-3.1.2.jar!/hive-log4j2.properties Async: true
Hive-on-MR is deprecated in Hive 2 and may not be available in the future versions. Consider using a different execution engine (i.e. spark, tez) or using Hive 1.X releases.
hive> _
从计划用户成功连接Mysql

尝试构建架构

user@node:~ schematool -dbType mysql -initSchema -verbose
Metastore connection URL:        jdbc:mysql://192.168.2.40:3306/metastore?createDatabaseIfNotExist=true&useSSL=false
Metastore Connection Driver :    com.mysql.jdbc.Driver
Metastore connection User:       hiveuser
Starting metastore schema initialization to 3.1.0
Initialization script hive-schema-3.1.0.mysql.sql
Exception in thread "main" java.lang.NoClassDefFoundError: org/apache/hive/jdbc/JdbcUriParseException ...
        at org.apache.hive.beeline.HiveSchemaTool.runBeeLine(HiveSchemaTool.java:1213)
        at org.apache.hive.beeline.HiveSchemaTool.runBeeLine(HiveSchemaTool.java:1204)
        at org.apache.hive.beeline.HiveSchemaTool.doInit(HiveSchemaTool.java:590)
        at org.apache.hive.beeline.HiveSchemaTool.doInit(HiveSchemaTool.java:567)
        at org.apache.hive.beeline.HiveSchemaTool.main(HiveSchemaTool.java:1517)
        at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
        at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
        at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
        at java.lang.reflect.Method.invoke(Method.java:498)
        at org.apache.hadoop.util.RunJar.run(RunJar.java:323)
        at org.apache.hadoop.util.RunJar.main(RunJar.java:236)
Caused by: java.lang.ClassNotFoundException: org.apache.hive.jdbc.JdbcUriParseException
        at java.net.URLClassLoader.findClass(URLClassLoader.java:382)
        at java.lang.ClassLoader.loadClass(ClassLoader.java:418)
        at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:355)
        at java.lang.ClassLoader.loadClass(ClassLoader.java:351)
        ... 11 more
努力调试自己-搜索JdbcUriParseException

在google上到处追踪,以确定这在配置单元代码中发生的位置-唯一远程关闭的是这个模块-提交91ab242,第1190行 但由于在我的输出中没有直线调用(可能在…11更多?),我无法确定参数(以下)在哪里导致问题

          try {
            jdbcConnectionParams = Utils.extractURLComponents(jdbcURL, new Properties());
          } catch (JdbcUriParseException e) {
这是hive站点.xml

<configuration>
        <property>
                <name>javax.jdo.option.ConnectionURL</name>
                <value>jdbc:mysql://192.168.2.40:3306/metastore?createDatabaseIfNotExist=true&amp;useSSL=false</value>
                <description>JDBC connect string for a JDBC metastore</description>
        </property>
        <property>
                <name>javax.jdo.option.ConnectionDriverName</name>
                <value>com.mysql.jdbc.Driver</value>
                <description>Driver class name for a JDBC metastore</description>
        </property>
        <property>
                <name>javax.jdo.option.ConnectionUserName</name>
                <value>hiveuser</value>
                <description>username to use against metastore database</description>
        </property>
        <property>
                <name>javax.jdo.option.ConnectionPassword</name>
                <value>NEVERYOUMIND</value>
                <description>password to use against metastore database</description>
        </property>
        <property>
                <name>hive.metastore.uris</name>
                <value>thrift://localhost:9083</value>
        </property>
</configuration>

javax.jdo.option.ConnectionURL
jdbc:mysql://192.168.2.40:3306/metastore?createDatabaseIfNotExist=true&usesl=false
JDBC元存储的JDBC连接字符串
javax.jdo.option.ConnectionDriverName
com.mysql.jdbc.Driver
JDBC元存储的驱动程序类名
javax.jdo.option.ConnectionUserName
蜂巢用户
用于元存储数据库的用户名
javax.jdo.option.ConnectionPassword
没关系
针对metastore数据库使用的密码
hive.metastore.uris
thrift://localhost:9083
数据库用户hiveuser连接并存在,并且可以在使用mysql cli和workbench时创建表

Java和Mysql连接器
已经尝试了各种方法,包括Java 11和Java 8-mysql版本5连接器和8连接器-所有这些方法都呈现相同的结果-因此我不确定这是否与JDBC相关-另一种观点将受到感激。

您的类路径中缺少了
hive JDBC
jar

在上查找类
org.apache.hive.jdbc.jdbcuripseexception
*
这个引擎能够找到包含类的jar

以下是未找到类异常的结果:


*我认为这个资源对于解决这样的问题是有用的,我不与该站点联系,也不通过任何平均的< /P>来促进它。实际的错误是“NoCuffDeffFunDror”。您不会得到“JdbcUriParseException”。问题是JVM找不到类“JdbcUriParseException”。问:既然您使用的是Hive,那么您是否在项目中包含了所有的Hive依赖项(包括Hive jdbc)(例如pom.xml或build.gradle)?谢谢paulsm4Many,非常感谢-结果是一个jar被建议移动,因为一些论坛说hadoop hdfs已经使用了它。好网站记住-书签!不客气:)这多次解决了我的问题,Hadoop-mini-clusters.jar似乎又在Hanks中包含了它!下一步停止理解配置单元的细微差别,以及为什么从文件加载只会创建空列-

<configuration>
        <property>
                <name>javax.jdo.option.ConnectionURL</name>
                <value>jdbc:mysql://192.168.2.40:3306/metastore?createDatabaseIfNotExist=true&amp;useSSL=false</value>
                <description>JDBC connect string for a JDBC metastore</description>
        </property>
        <property>
                <name>javax.jdo.option.ConnectionDriverName</name>
                <value>com.mysql.jdbc.Driver</value>
                <description>Driver class name for a JDBC metastore</description>
        </property>
        <property>
                <name>javax.jdo.option.ConnectionUserName</name>
                <value>hiveuser</value>
                <description>username to use against metastore database</description>
        </property>
        <property>
                <name>javax.jdo.option.ConnectionPassword</name>
                <value>NEVERYOUMIND</value>
                <description>password to use against metastore database</description>
        </property>
        <property>
                <name>hive.metastore.uris</name>
                <value>thrift://localhost:9083</value>
        </property>
</configuration>