springBoot整合dubbo 注解方式及采坑记录

在搭建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 端口就 服务端 消费端 端口是否被占用,如被占用,请修改相关端口

发布了59 篇原创文章 · 获赞 3 · 访问量 2997

猜你喜欢

转载自blog.csdn.net/weixin_41003771/article/details/102859260