Hive启动报错:java.lang.NoSuchMethodError: com.google.common.base.Preconditions.checkArgument


项目场景:

系统:Ubuntu20.04
Hadoop版本:Hadoop3.3.1
Hive版本:Hive3.1.2


问题描述:

在启动 Hive 时,出现如下输出:

hadoop@fzqs-Laptop:/usr/local/hive/lib$ hive -version
Exception in thread "main" java.lang.NoSuchMethodError: com.google.common.base.Preconditions.checkArgument(ZLjava/lang/String;Ljava/lang/Object;)V
	at org.apache.hadoop.conf.Configuration.set(Configuration.java:1357)
	...
	at org.apache.hadoop.util.RunJar.main(RunJar.java:236)

原因分析:

这是因为 hive 内依赖的 guava.jar 和 hadoop 内的版本不一致造成的。


解决方案:

查看 hadoop 安装目录下的 guava.jar 版本:

ls /usr/local/hadoop/share/hadoop/common/lib/guava*

输出如下:

hadoop@fzqs-Laptop:/usr/local/hadoop/share/hadoop/common/lib$ ls /usr/local/hadoop/share/hadoop/common/lib/guava*
/usr/local/hadoop/share/hadoop/common/lib/guava-27.0-jre.jar

接着查看 Hive 下的 guava.jar 版本:

ls /usr/local/hive/lib/guava*

输出如下:

hadoop@fzqs-Laptop:/usr/local/hadoop/share/hadoop/common/lib$ ls /usr/local/hive/lib/guava*
/usr/local/hive/lib/guava-19.0.jar

可以看到 Hadoop 内的 guava.jar 版本是要高于 Hive 内带的的,所以使用 Hadoop 的替代 Hive 的:

sudo rm /usr/local/hive/lib/guava-19.0.jar
sudo cp /usr/local/hadoop/share/hadoop/common/lib/guava-27.0-jre.jar /usr/local/hive/lib

问题解决。

评论 7
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

Z.Q.Feng

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

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

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

打赏作者

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

抵扣说明:

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

余额充值