解决Elasticsearch和Phoenix、HBase的com.google.guava冲突

本文介绍了Elasticsearch 2.4.1依赖Guava 18.0以上版本,而Phoenix和HBase依赖16.0以下版本导致的冲突问题。冲突的关键在于Guava 17.0版本的重大改动。常见的错误是`com.google.common.base.Stopwatch.()V`。解决方案是使用maven-shade-plugin重新打包Elasticsearch,将Guava包名更名,避免版本冲突。通过创建新的Maven工程,修改pom.xml,打包并上传到maven仓库,然后在项目中引用改名后的Elasticsearch依赖和低版本Guava。
摘要由CSDN通过智能技术生成

冲突原因

Elasticsearch 2.4.1 依赖com.google.guava18.0以上版本

Phoenix 和 HBase  依赖com.google.guava16.0以下版本

guava 17.0 为临界版本,做了较大改动,导致版本不兼容

常见报错

com.google.common.base.Stopwatch.()V from class org.apache.hadoop.hbase.zookeeper.MetaTableLocator

解决方案

ES官方方案

https://www.elastic.co/blog/to-shade-or-not-to-shade

方案原理

利用maven-shade-plugin,它可以把依赖的包打包进项目的jar,并且可以重新命名依赖包的包名。这样编译后,Elasticsearch使用的是重新命名的guava18.0包,不再依赖项目中引用的guava16.0版本。

具体实现

用Maven新建工程,只修改pom.xml文件

<?xml version="1.0" encoding="UTF-8"?>

<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi=
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值