启动hive出现 ls: 无法访问/opt/module/spark/lib/spark-assembly-*.jar: 没有那个文件或目录

启动hive的时候出现如下错误

[root@Bigdata01 bin]# hive
ls: 无法访问/opt/module/spark/lib/spark-assembly-*.jar: 没有那个文件或目录
20/09/03 20:29:03 WARN conf.HiveConf: HiveConf of name hive.metastore.local does not exist

Logging initialized using configuration in jar:file:/opt/module/hive/lib/hive-common-1.2.1.jar!/hive-log4j.properties
hive (default)>

原因是:

spark升级到spark2以后,原有lib目录下的大JAR包被分散成多个小JAR包,原来的spark-assembly-*.jar已经不存在,所以hive没有办法找到这个JAR包。

解决办法是:修改bin目录下的hive文件

[root@Bigdata01 bin]# vim hive

找到以下内容:

add Spark assembly jar to the classpath
if [[ -n “$SPARK_HOME” ]]
then
sparkAssemblyPath=ls ${SPARK_HOME}/lib/spark-assembly-*.jar
CLASSPATH=" C L A S S P A T H : {CLASSPATH}: CLASSPATH:{sparkAssemblyPath}"
fi

将标红处 修改为:sparkAssemblyPath=ls ${SPARK_HOME}/jars/*.jar

再次启动

[root@Bigdata01 bin]# vim hive
[root@Bigdata01 bin]# ./hive
20/09/03 20:33:53 WARN conf.HiveConf: HiveConf of name hive.metastore.local does not exist

Logging initialized using configuration in jar:file:/opt/module/hive/lib/hive-common-1.2.1.jar!/hive-log4j.properties
hive (default)> 

OK,问题解决。

这也印证了各个软件升级过程中如何涉及到自动联运或者向下兼容的问题。

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值