跟着视频做的时候,有很多不一样的地方,随着我一步步的试错,报了如下各种错误:
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>
一定得在提供者运行的情况下再运行消费者,不然会报错没有提供者