在搭建springBoot+dubbo项目过程中,需要导入什么dubbo包,在application.properties中,有需要哪些注解配置
一、pom.xml导入
第一种:
<!--dubbo-->
<dependency>
<groupId>io.dubbo.springboot</groupId>
<artifactId>spring-boot-starter-dubbo</artifactId>
<version>1.0.0</version>
</dependency>
<!-- zookeeper客户端 -->
<dependency>
<groupId>com.101tec</groupId>
<artifactId>zkclient</artifactId>
<version>0.7</version>
</dependency>
导入zookeeper客户端时,如果出现slf4j日志包冲突,需要改成如下导入,移除嵌入日志包:
<!-- zookeeper客户端 -->
<dependency>
<groupId>com.101tec</groupId>
<artifactId>zkclient</artifactId>
<version>0.7</version>
<!-- 移除嵌入日志包 打包-->
<exclusions>
<exclusion>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-log4j12</artifactId>
</exclusion>
<exclusion>
<groupId>log4j</groupId>
<artifactId>log4j</artifactId>
</exclusion>
</exclusions>
</dependency>
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>log4j-over-slf4j</artifactId>
<version>1.7.25</version>
</dependency>
application.properties中的注解配置:
服务端:
服务端:
#dubbo应用名称 #这个必须要
spring.dubbo.application.name=service-provider
#注册中心的协议和地址
spring.dubbo.registry.protocol=zookeeper
spring.dubbo.registry.address=zookeeper://127.0.0.1:2181
#通信规则(通信协议和接口)
spring.dubbo.protocol.name=dubbo
spring.dubbo.protocol.port=20880
#开启包扫描,可替代 @EnableDubbo 注解 保险最好还是加上
spring.dubbo.scan.base-packages=com.base.dubbo.serviceImpl
消费端:
#dubbo应用名称 #这个必须要 记住是 dubbo.application.name
dubbo.application.name=service-consumer
dubbo.registry.address=zookeeper://zookeeper服务地址:2181
代码
一、不管是服务端,还是消费端 Application 上一定要加上@EnableDubbo注解
二、服务端的服务实现是,需要增加@Service注解,必须要带版本号,具体如下:
@Component
@Service(version = "1.0.0",timeout = 10000,interfaceClass = RemoteUserService.class)
完整类如下:
@Component
@Service(version = "1.0.0",timeout = 10000,interfaceClass = RemoteUserService.class)
public class RemoteUserServiceImpl implements RemoteUserService {
private static final Logger logger = LoggerFactory.getLogger(RemoteUserServiceImpl.class);
@Override
public String sayHello(String name) {
logger.debug("进入请求服务");
return "Hello "+name;
}
}
三、消费端引用服务时,需要@Reference(version = “1.0.0”)注解,必须带版本号,具体如下
@Reference(version = "1.0.0")
private RemoteUserService remoteUserService;
采坑点
一、dubbo有几种不同的依赖包,每种依赖包的application.properties注解配置也不一样,请确认自己引用的是那种依赖包,具体可参考以下文章
https://blog.csdn.net/qq_35713827/article/details/95071617
二、消费端启动时,无法找到 application.name=null 或找不到 application.name
application.properties 中增加 dubbo.application.name=service-consumer 配置,请注意,是dubbo.application.name,不是spring.application.name,也不是 spring.dubbo.application.name
三、服务或者服务实现层找不到,如 RemoteUserService 或 RemoteUserServiceImpl
请检查 Application 上是否有 @EnableDubbo
四、slf4j 冲突,具体可见以上pom配置
五、dubbo服务端找不到,请检查dubbo服务端是否启动,可打开dubbo管理工具查看,具体如下:
https://blog.csdn.net/weixin_41003771/article/details/102859025
六、相关端口冲突,请检查 spring.dubbo.protocol.port=20880 端口就 服务端 消费端 端口是否被占用,如被占用,请修改相关端口