实战思路-解决Hadooop生态圈的兼容问题

在使用Hadoop生态开源软件过程中,不同软件的版本不兼容是经常出现的问题,主要表现为项目代码在编译的过程中出现:ClassNotFound或者NoSuchMethod的异常。

ClassNotFoundError:
在这里插入图片描述
NoSuchMethodError:
在这里插入图片描述
这些错误绝大部分情况下是由于不同软件版本的不兼容导致的,比如Hive3.1.2与Spark3不兼容。

Hive3.1.2兼容Spark2,在Hive源码的包中,可以查看到其pom中的spark依赖是2.4.5,也就是说Hive3.1.2使用了Spark2.4.5中的Api,但在项目环境中,只有Spark3的jar包,而Spark3已经对Spark2进行了修改,修改包含对类的删除和方法声明的修改,在这种情况下,编译项目时就会出现上述错误。

解决办法:

一,将spark jar包替换为2.4.5

这种方法最简单直接,但有时并不可行,出现按下葫芦浮起瓢的情况,解决了这个报错,又出现另一个类似的错误,主要是因为其他软件依赖的是spark3。这样的话,就只能走第二种解决方法。

二,编译Hive源码,将其spark依赖改为Spark3

在这个过程中,可以会出现错误,比如之前提到的两个找不到类和方法,修改源码就是唯一的解决方法,庆幸的是,大多数情况下,这种修改不会特别复杂。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

小手追梦

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

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

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

打赏作者

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

抵扣说明:

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

余额充值