1.问题描述,在使用springboot整合phoneix操作数据库时,之前测试一直正常,后来为为项目引入swagger2进行接口展示时,发现调不通hbase了,报错如下:
"Handler dispatch failed; nested exception is java.lang.IllegalAccessError: tried to access method com.google.common.collect.Iterators.emptyIterator()Lcom/google/common/collect/UnmodifiableIterator; from class org.apache.phoenix.schema.MetaDataClient"
2.初步看是报了google相关的错误,解决:
#将项目依赖的jar包列出来
mvn dependency:resolve
#发现找不到有相同版本的依赖
#查看依赖图
mvn dependency:tree
#加过滤条件,以groupId:artifactId:version的方式进行过滤
mvn dependency:tree -Dverbose -Dincludes=com.google.guava:guava
使用命令也看不出来,真狗
3.直接点击pom文件进去查看父级引用,最后找到guava引用的是13版本
4.根据路劲最短原则,是引用了swagger2版本中的guava,所以将swagger2中的版本排除掉
<dependency>
<groupId>io.springfox</groupId>
<artifactId>springfox-swagger2</artifactId>
<version>2.9.2</version>
<exclusions>
<exclusion>
<groupId>com.google.guava</groupId>
<artifactId>guava</artifactId>
</exclusion>
</exclusions>
</dependency>
解决jar包冲突:mavenjar包冲突解决技巧