stopwatch 依赖_HBase/Spark Guava依赖冲突解决方案

当Spark2.2.0与HBase1.0.0-cdh5.6.0集成时,由于Guava16.0后的版本不向后兼容,导致出现DoNotRetryIOException。解决办法是使用maven-shade-plugin打包HBase依赖,重命名Guava包以避免冲突,然后在Spark中引用打包后的HBase库。
摘要由CSDN通过智能技术生成

前言

版本

guava 版本

Spark

2.2.0

12.0.1

HBase

1.0.0-cdh5.6.0

20.0

由于guava的版本在16.0以后,不向后兼容,所以Spark程序中集成HBase是会报找不到依赖的方法错误, 如下:

Caused by: org.apache.hadoop.hbase.DoNotRetryIOException: java.lang.IllegalAccessError: tried to access method com.google.common.base.Stopwatch.()V from class org.apache.hadoop.hbase.zookeeper.MetaTableLocator

at org.apache.hadoop.hbase.client.RpcRetryingCaller.translateException(RpcRetryingCaller.java:229)

at org.apache.hadoop.hbase.client.RpcRetryingCaller.callWithoutRetries(RpcRetryingCaller.java:202)

at org.apache.hadoop.hbase.client.ClientScanner.call(ClientScanner.java:326)

at org.apache.hadoop.hbase.client.ClientScanner.nextScanner(ClientScanner.java:301)

at org.apache.hadoop.hbase.client.ClientScanner.initializeScannerInConstruction(ClientScanner.java:166)

at org.apache.hadoop.hbase.client.ClientScanner.(ClientScanner.java:161)

at org.apache.hadoop.hbase.client.HTable.getScanner(HTable.java:794)

at org.springframework.data.hadoop.hbase.HbaseTemplate$1.doInTable(HbaseTemplate.java:132)

at org.springframework.data.hadoop.hbase.HbaseTemplate.execute(HbaseTemplate.java:61)

... 75 more

解决方案

使用 maven-shade-plugin 打包hbase依赖,把依赖的包打包进项目,并且修改依赖包的包名,这样hbase引用的就是修改包名后的guava包了,不在依赖原生的guava包。

xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"

xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">

xql

com.xxx.xxx.xxx

1.0.0

4.0.0

your-hbase

org.apache.hbase

hbase-server

1.0.0

com.google.guava

guava

org.apache.hbase

hbase-common

1.0.0

com.google.guava

guava

16.0

org.apache.maven.plugins

maven-shade-plugin

3.0.0

package

shade

*:*

META-INF/*.SF

META-INF/*.DSA

META-INF/*.RSA

然后,spark集成hbase时,引用maven-shade-plugin打包后的hbase包,冲突解决。

com.xxx.xxx.xxx

your-hbase

1.0.0

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值