springboot整合dubbo和zookeeper时候各种报错问题

tech2022-07-11  173

跟着视频做的时候,有很多不一样的地方,随着我一步步的试错,报了如下各种错误: java.lang.NoClassDefFoundError: org/apache/curator/RetryPolicy, java.lang.NoClassDefFoundError: org/apache/zookeeper/Watcher, @DubboReference dependencies is failed, java.lang.NoClassDefFoundError: , org/apache/curator/utils/DefaultZookeeperFactory, java.lang.NoClassDefFoundError: org/apache/curator/RetryPolicy, java.lang.NoClassDefFoundError: , org/apache/curator/framework/CuratorFrameworkFactory,

这些基本都是导入各种依赖不对乃至版本冲突等原因

在此记录一下: 主要是一个服务提供者,一个消费者,将它们在zookeeper中注册,然后消费者访问到 提供者中的方法才算成功,这里就不贴service层各种代码了,但是在提供者的service层中,视频中的注解为@Service,但是这个Service注解和原来的不一样,原来的是spring的注解,但是这个是Service是dubbo的service,但是可能由于版本的更新,不管是alibaba还是apache的这个Service都已经过时了: 这里用的是@DubboService 是为了将服务发布出去 application类中要加入@EnableDubbo,,好像是springboot 2.x之后的改变造成的,如果不加的话,之后我们在消费端的注入会失败或者报错。 提供者的pom文件,省略了自动生成的,只写了额外引用的:

<dependency> <groupId>org.apache.curator</groupId> <artifactId>curator-recipes</artifactId> <version>4.0.1</version> </dependency> <dependency> <groupId>org.apache.zookeeper</groupId> <artifactId>zookeeper</artifactId> <version>3.6.1</version> <exclusions> <exclusion> <groupId>org.slf4j</groupId> <artifactId>slf4j-log4j12</artifactId> </exclusion> </exclusions> </dependency> <!-- dubbo依赖 --> <dependency> <groupId>org.apache.dubbo</groupId> <artifactId>dubbo-spring-boot-starter</artifactId> <version>2.7.7</version> </dependency> <!-- zookeeper客户端 --> <dependency> <groupId>com.github.sgroschupf</groupId> <artifactId>zkclient</artifactId> <version>0.1</version> </dependency>

服务提供者这边启动成功:

再来看看消费者这边: 这个service注解是spring的注解,远程引用ticketService,视频里加的是@Reference,但是可以看到,这个注解也过世了 因此用的是@DubboReference

消费者的pom文件,省略了自动生成的,只写了额外引用的:和提供者略微不一样:

<!-- https://mvnrepository.com/artifact/org.apache.curator/curator-recipes --> <dependency> <groupId>org.apache.curator</groupId> <artifactId>curator-recipes</artifactId> <version>5.1.0</version> </dependency> <dependency> <groupId>org.apache.zookeeper</groupId> <artifactId>zookeeper</artifactId> <version>3.6.1</version> <exclusions> <exclusion> <groupId>org.slf4j</groupId> <artifactId>slf4j-log4j12</artifactId> </exclusion> </exclusions> </dependency> <!-- dubbo依赖 --> <dependency> <groupId>org.apache.dubbo</groupId> <artifactId>dubbo-spring-boot-starter</artifactId> <version>2.7.7</version> </dependency> <!-- zookeeper客户端 --> <dependency> <groupId>com.github.sgroschupf</groupId> <artifactId>zkclient</artifactId> <version>0.1</version> </dependency>

一定得在提供者运行的情况下再运行消费者,不然会报错没有提供者

最新回复(0)