当我们进入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
/
下载好之后上传到Linux系统当中,然后解压并配置环境变量
使用Derby数据库存储元数据
初始化元数据库bin/schematool -dbType derby -initSchema
使用MySQL充当Hive元数据
这样做的好处就是多用户协调
cp JDBC驱动包位置 $HIVE_HOME/lib
<configuration>
<property>
<name>javax.jdo.option.ConnectionURLname>
<value>jdbc:mysql://安装的机器上:3306/metastore?useSSL=falsevalue>
property>
<property>
<name>javax.jdo.option.ConnectionDriverNamename>
<value>com.mysql.jdbc.Drivervalue>
property>
<property>
<name>javax.jdo.option.ConnectionUserNamename>
<value>mysql的用户value>
property>
<property>
<name>javax.jdo.option.ConnectionPasswordname>
<value>mysql设置的密码value>
property>
<property>
<name>hive.metastore.schema.verificationname>
<value>falsevalue>
property>
<property>
<name>hive.metastore.event.db.notification.api.authname>
<value>falsevalue>
property>
<property>
<name>hive.metastore.warehouse.dirname>
<value>/user/hive/warehousevalue>
property>
configuration>
systemctl start mysql
mysql -uroot -p
create database metastore
quit
schematool -initSchema -dbType mysql -verbose
$HADOOP_HOME/sbin/start-all.sh
bin/hive
show tables;