Hive异常:报错:org.apache.hadoop.conf.Configuration.getPassword(Ljava/lang/String;)[C-解决问题同时搭建Hive环境

一、问题分析

当我们进入Hive Shell窗口时,执行HQL操作将会报错:
Unable to instantiate org.apache.hadoop.hive.ql.metadata.SessionHiveMetaStoreClient

然后还会报出异常
org.apache.hadoop.conf.Configuration.getPassword(Ljava/lang/String;)

我的环境是3.1的Hive和Hadoop3.x的,官方的解释是支持的,可能是jar包的绑定冲突,因为大数据是一个生态圈,可能一个不兼容的问题,导致整个的生态的崩溃。
所以万事不决洛必达
直接降版本
来到清华开源的软件镜像站,下载一个2.3.9的Hive
https://mirrors.tuna.tsinghua.edu.cn/
在这里插入图片描述

点进apache下找到hive目录下,就能看到
在这里插入图片描述

二、解决问题

下载好之后上传到Linux系统当中,然后解压并配置环境变量

使用Derby数据库存储元数据
初始化元数据库

bin/schematool -dbType derby -initSchema

使用MySQL充当Hive元数据

这样做的好处就是多用户协调

1、将JDBC驱动拷入到Hive家目录下的lib目录

cp JDBC驱动包位置  $HIVE_HOME/lib

2、在Hive家目录/conf创建一个hive-site.xml文件

<?xml version="1.0"?>
<?xml-stylesheet type="text/xsl" href="configuration.xsl"?>
<configuration>
 <!-- jdbc 连接的 URL -->
 <property>
 <name>javax.jdo.option.ConnectionURL</name>
 <value>jdbc:mysql://安装的机器上:3306/metastore?useSSL=false</value>
</property>
 <!-- jdbc 连接的 Driver-->
 <property>
 <name>javax.jdo.option.ConnectionDriverName</name>
 <value>com.mysql.jdbc.Driver</value>
</property>
<!-- jdbc 连接的 username-->
 <property>
 <name>javax.jdo.option.ConnectionUserName</name>
 <value>mysql的用户</value>
 </property>
 <!-- jdbc 连接的 password -->
 <property>
 <name>javax.jdo.option.ConnectionPassword</name>
 <value>mysql设置的密码</value>
</property>
 <!-- Hive 元数据存储版本的验证 -->
 <property>
 <name>hive.metastore.schema.verification</name>
 <value>false</value>
</property>
 <!--元数据存储授权-->
 <property>
 <name>hive.metastore.event.db.notification.api.auth</name>
 <value>false</value>
 </property>
 <!-- Hive 默认在 HDFS 的工作目录 -->
 <property>
 <name>hive.metastore.warehouse.dir</name>
 <value>/user/hive/warehouse</value>
 </property>
</configuration>

3、登录到MySQL创建数据库metastore

systemctl start mysql
mysql -uroot -p
create database metastore
quit

4、初始化元数据库

schematool -initSchema -dbType mysql -verbose

5 、启动Hadoop集群

$HADOOP_HOME/sbin/start-all.sh

6、启动Hive

bin/hive
show tables;

在这里插入图片描述
到这里就结束了,也就成功了,希望小伙们能记住这个问题,也别忘了收藏哦⭐⭐⭐

  • 12
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 7
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 7
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

Philosophy7

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

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

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

打赏作者

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

抵扣说明:

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

余额充值