最近在学习分布式锁的实现方式,我采用 Apache 开源的curator 开实现 Zookeeper 分布式锁。
curator 、zookeeper 、 guava三个版本兼容的问题需要注意
15:41:50.561 [main] INFO org.apache.curator.framework.imps.CuratorFrameworkImpl - Starting
Exception in thread "main" java.lang.NoSuchMethodError: com.google.common.util.concurrent.MoreExecutors.sameThreadExecutor()Lcom/google/common/util/concurrent/ListeningExecutorService;
at org.apache.curator.framework.listen.ListenerContainer.addListener(ListenerContainer.java:41)
at org.apache.curator.framework.imps.CuratorFrameworkImpl.start(CuratorFrameworkImpl.java:257)
at com.itstyle.seckill.distributedlock.zookeeper.CuratorUtil.main(CuratorUtil.java:26)
从错误的字面意思上可以判断是MoreExecutors这个类中缺少sameThreadExecutor这个方法,查看MoreExecutors源码,这个类中确实是缺少sameThreadExecutor这个方法。
导致这个问题的原因是guava的版本和curator-recipes版本不对应导致的,把项目对curator-recipes的依赖改成高版本就不会出现这个问题了
只加 curator-recipes 好像不太行 最好加上curator-framework、curator-client
<!--guava-->
<dependency>
<groupId>com.google.guava</groupId>
<artifactId>guava</artifactId>
<version>23.0</version>
</dependency>
<!--zookeeper-->
<dependency>
<groupId>org.apache.zookeeper</groupId>
<artifactId>zookeeper</artifactId>
<version>3.4.6</version>
</dependency>
<!--zookeeper curator-->
<dependency>
<groupId>org.apache.curator</groupId>
<artifactId>curator-recipes</artifactId>
<version>4.0.0</version>
</dependency>
<dependency>
<groupId>org.apache.curator</groupId>
<artifactId>curator-framework</artifactId>
<version>4.0.0</version>
</dependency>
<dependency>
<groupId>org.apache.curator</groupId>
<artifactId>curator-client</artifactId>
<version>4.0.0</version>
</dependency>
原文链接:https://blog.csdn.net/xiongyouqiang/article/details/85704709