Hive 3.1 guava 导致 异常

异常日志

2021-08-18 09:43:25,100 ERROR [main] org.apache.hadoop.mapreduce.v2.app.MRAppMaster: Error starting MRAppMaster
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.conf.Configuration.set(Configuration.java:1338)
	at org.apache.hadoop.mapreduce.v2.app.MRAppMaster.main(MRAppMaster.java:1690)
2021-08-18 09:43:25,104 INFO [main] org.apache.hadoop.util.ExitUtil: Exiting with status 1: java.lang.NoSuchMethodError: com.google.common.base.Preconditions.checkArgument(ZLjava/lang/String;Ljava/lang/Object;)V

原因分析:

Hadoop 3.1 使用的 guava 版本是 27.0-jre, 而 hive 3.1 使用的 guava 版本是 19.0,把下载的 hive/lib 下的 guava-19.0.jar 删除,并且把 Hadoop share/hadoop/common/lib 下的 guava-27.0-jre.jar 拷贝过来不能解决问题,因为 已经把 guava 的类打入 hive-exec.jar。所以,只要 hive-exec.jar 不变,就会抛出这个异常。

解决方案1:

Hadoop 和 hive 用 guava-23.6-jre 这个版本编译。hive 需修改 DruidScanQueryRecordReader Iterators.emptyIterator() 的 访问权限 改为 package access,外界访问不了。

解决方案2:

把 hadoop 的 classpath 放到前面,把 mapred-site.xml 增加或修改以下配置。

<property>
  <name>mapreduce.job.user.classpath.first</name>
  <value>false</value>
</property>
<property>
   <name>mapreduce.user.classpath.first</name>
   <value>false</value>
</property>

解决方案3:

把 hive-exec-${HIVE_VERSION}.jar 解压,删除 guava 的代码,重新生成 hive-exec-${HIVE_VERSION}.jar

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值