Hive错误: java.lang.RuntimeException: Unable to instantiate org.apache.hadoop.hive.ql.metadata.Session

2 篇文章 1 订阅

1. 今天在使用hive客户端时,执行查询语句报错如下:

FAILED: SemanticException org.apache.hadoop.hive.ql.metadata.HiveException:
java.lang.RuntimeException: Unable to instantiate 
org.apache.hadoop.hive.ql.metadata.SessionHiveMetaStoreClient

在这里插入图片描述

2. 原因分析:服务端未开启服务,在hive服务端使用命令:hive --service metastore &
再在客户端使用hive命令连接 (注意:客户端与服务端一般不在同一节点)
在这里插入图片描述

3. 网上其他解决方案:hive的数据库MySQL在安装的时候没有初始化
解决方案:初始化数据库,命令:schematool -dbType mysql -initSchema
在这里插入图片描述

初始化时又遇到下面的错误

Error: Duplicate key name 'PCS_STATS_IDX' (state=42000,code=1061)
org.apache.hadoop.hive.metastore.HiveMetaException: Schema initialization FAILED!
Metastore state would be inconsistent !!
Underlying cause: java.io.IOException : Schema script failed, errorcode 2
Use --verbose for detailed st

在这里插入图片描述
3. 原因分析:初始化的时候就会创建数据库hive,第一次初始化就已经生成,如果后面继续初始化还会继续执行这一步,但是执行到这时不能创建名字相同的数据库,就会报错以上错误信息,解决办法就是打开我们的mysql数据库,将这个hive数据库删除,继续初始化就可以成功了。

(1) 查看库名:show databases;
在这里插入图片描述

(2) 删除数据库:drop database hive;
在这里插入图片描述
(3) 重新执行初始化命令:schematool -dbType mysql -initSchema 即可成功
在这里插入图片描述

4. 检查:在hive的lib下加入适合自己节点的mysql驱动
在这里插入图片描述

5. 在hive服务端使用命令:hive --service metastore &,客户端中使用hive连接,即可正常使用hive
在这里插入图片描述

  • 20
    点赞
  • 91
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 4
    评论
### 回答1: 这是一个Hive异常,其中包含了一个Java异常:java.lang.RuntimeException,该异常表示无法实例化org.apache.hadoop.hive.ql.metadata.SessionHiveMetaStoreClient。 ### 回答2: 这个错误信息是Hive元数据客户端无法创建实例的错误。可能是由于以下原因导致的: 1.配置错误:首先,我们需要检查Hive配置文件是否正确。我们需要确保指定的配置文件中,所有参数都正确。特别是我们需要检查是否正确地指定了Hive Metastore的地址、端口和用户名等信息。 2.环境问题:Hive需要访问Hadoop环境中的许多组件,例如HDFS,YARN和Zookeeper。如果这些组件无法正常工作,就会导致Hive无法工作。因此,我们需要确保这些组件已经启动,并且没有出现任何故障或错误。 3.权限问题:Hive Metastore需要访问Hadoop中的一些文件和目录。所以我们需要确保Hive用户有足够的权限来访问这些文件和目录。通常情况下,我们需要确保Hive用户有足够的权限来访问所有的Hadoop文件和目录。 4.版本不兼容:如果Hive代码与Hadoop代码版本不兼容,则会出现这个错误信息。因此,我们需要确保HiveHadoop的版本是兼容的。我们可以查看Hive文档来了解HiveHadoop版本的兼容性情况。 以上是可能导致出现该错误信息的一些原因,根据具体情况,我们需要针对性的解决问题。 ### 回答3: 这个错误的出现是由于Hive无法实例化SessionHiveMetaStoreClient,这通常是由以下一些原因引起的: 1. Hive metastore守护程序未正常运行:Hive metastore守护程序是Hive使用的关键进程之一,它维护着Hive的元数据存储库,包括表、分区、列和扫描器等信息。如果这个守护程序没有正常运行,那么Hive无法连接到元数据存储库,也就无法实例化SessionHiveMetaStoreClient。在这种情况下,可以通过检查守护程序日志以及运行Hive metastore守护程序的相关进程来诊断问题。 2. 元数据存储库连接失败:如果Hive metastore守护程序运行正常,但Hive仍然无法实例化SessionHiveMetaStoreClient,则可能是元数据存储库连接失败。在这种情况下,可以检查Hive配置文件中的元数据存储库连接参数,例如连接URL、用户名和密码等,以确保它们正确且可访问。 3. Hive版本与Hadoop版本不兼容:Hive是一个在Hadoop生态系统中构建的工具,它依赖于Hadoop的许多组件。如果Hive版本与Hadoop版本不兼容,则可能出现类似的错误。在这种情况下,可以尝试将HiveHadoop版本升级或降级到兼容的版本。 4. 其他问题:除了上述原因之外,SessionHiveMetaStoreClient实例化失败的原因还有很多,例如Java环境问题、操作系统问题等。在这些情况下,可以根据错误提示和日志来进行进一步的诊断和排除。
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

bug 

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值