微服务springboot集成dubbo采用注解的方式

 

     微服务就是将一个完整的系统,按照不同的业务功能,拆系统分成一个个独立的子系统,在微服务结构中,每个子系统就被称为“服务”。这些子系统能够独立运行在web容器中,它们之间通过RPC方式通信。例如我们开发一个管理系统,按照微服务的思想,我们需要拆分为人事服务、办公事务服务、进销存服务等等。这一个个服务都是一个个独立的项目,可以独立运行。如果服务之间有依赖关系,那么通过RPC方式调用,RPC方式调用,我们可以采用阿里的dubbo框架。

采用RPC的优点:

1、降低系统间的耦合度,可独立开发业务模板,开发时只需启动必要的服务,其他业务服务无需启动。

2、增加代码复用性。

本项目的目录结构:生产者+消费者+公共接口

框架:springboot+dubbo+zk

第一步:创建父子结构的项目

最后的目录:comom为公共接口与实体类,myprovide为服务提供者,mycustomer为服务消费者。

微服务springboot集成dubbo采用注解的方式_第1张图片

第二步:导入所需的公共jar,这可以在父的pom中引入。



    4.0.0
    
        org.springframework.boot
        spring-boot-starter-parent
        2.1.6.RELEASE
         
    
    com.janion
    demo
    0.0.1-SNAPSHOT
    demo
    Demo project for Spring Boot

    
        1.8
        1.16.18
    

    
        
        mycustomer
        
        myprovide
        
        comom
    


    
        
            org.springframework.boot
            spring-boot-starter
        

        
            org.springframework.boot
            spring-boot-starter-web
        

        
            org.springframework.boot
            spring-boot-starter-test
            test
        

        
        
            
            
            
        

        
        
            mysql
            mysql-connector-java
            runtime
        

        
        
            io.dubbo.springboot
            spring-boot-starter-dubbo
            1.0.0
            
                     
                    com.alibaba
                    dubbo
                
                     
                    com.101tec
                    zkclient
                
            
        
        
        
            com.alibaba
            dubbo
            2.6.0
            
            
                
                    org.javassist
                    javassist
                
            
        

        
        
            com.github.sgroschupf
            zkclient
            0.1
            
                
                    zookeeper
                    org.apache.zookeeper
                
            
        

        
            org.apache.zookeeper
            zookeeper
            3.4.9
            
                
                    slf4j-log4j12
                    org.slf4j
                
                
                    log4j
                    log4j
                
            
        
        
        
            org.springframework.boot
            spring-boot-starter-aop
        
    


    
        
            
                org.springframework.boot
                spring-boot-maven-plugin
            
        
    


第三步:配置生产者的依赖。其中dubbo启动未找到bean,需导入javasisit,否则dubbo启动会报错,未找到dubbo的相关bean文件。



    4.0.0
    com.myprovide
    myprovide
    0.0.1-SNAPSHOT
    myprovide
    Demo project for Spring Boot
    
        com.janion
        demo
        0.0.1-SNAPSHOT
        ../pom.xml
    
    
        1.8
    

    
        
            com.comom
            demo
            0.0.1-SNAPSHOT
        
        
            org.springframework.boot
            spring-boot-starter-web
        
        
        
            org.javassist
            javassist
            3.20.0-GA
        
        
            org.springframework.boot
            spring-boot-starter-test
            test
            
                
                    org.junit.vintage
                    junit-vintage-engine
                
            
        
    

    
        
            
                org.springframework.boot
                spring-boot-maven-plugin
            
        
    


这里的zk采用的集群的方式,可自行百度集群的搭建方式。


server:
  port : 8080
spring:
  #发布应用程序配置
  application:
    name: myprovide


  dubbo:
    application:
      name: myprovide   #提供方应用信息
    registry:
      address: zookeeper://127.0.0.1:2181?backup=127.0.0.1:2182,127.0.0.1:2183 #使用zookeeper注册中心暴露服务地址
    protocol:
      name: dubbo
      port: -1    #配置暴露服务端口 -1为随机端口
    scan: com.myprovide.myprovide.service.impl   #扫描需要暴露的服务

生产者的代码块,其中service,需引入dubbo的方法。

微服务springboot集成dubbo采用注解的方式_第2张图片

好了,到目前为止dubbo生产者已经搭建完成,我们可以启动生成zk和服务检测生成者是否搭建注册成功。

服务开始注册zk

微服务springboot集成dubbo采用注解的方式_第3张图片

然后我们可以进去zk去查看生产者是否注册成功,可通过cmd进行查看,进入zk的安装目录下的bin文件中,打开zkCli.cmd。

输入:ls /dubbo/com.comom.demo.service.UserService/providers,若显示一下信息,则表示注册成功,可以进行暴露服务给消费者使用了。

第四步:配置消费者

配置pom文件



    4.0.0
    com.mycustomer
    demo
    0.0.1-SNAPSHOT
    demo
    Demo project for Spring Boot
    
    com.janion
    demo
    0.0.1-SNAPSHOT
    ../pom.xml

    
        1.8
    

    
        
            com.comom
            demo
            0.0.1-SNAPSHOT
        

        
            com.alibaba.spring
            spring-context-support
            1.0.2
        

        
            org.springframework.boot
            spring-boot-starter-web
        

        
        
            org.javassist
            javassist
            3.20.0-GA
        

        
            org.springframework.boot
            spring-boot-starter-test
            test
            
                
                    org.junit.vintage
                    junit-vintage-engine
                
            
        
    

    
        
            
                org.springframework.boot
                spring-boot-maven-plugin
            
        
    


配置yml文件

server:
  port : 8081
spring:
  application:
    name: mycustomer
  dubbo:
    application:
      name: mycustomer
    registry:
      address: zookeeper://127.0.0.1:2181?backup=127.0.0.1:2182,127.0.0.1:2183 #使用zookeeper注册中心暴露服务地址
    scan: com.mycustomer.demo.controller

好了,现在可以开始测试dubbo提供的服务了。

微服务springboot集成dubbo采用注解的方式_第4张图片

1、调用服务需使用@Reference,对应好服务的版本号。

对于引入服务为空指针有两种解决方式

(1)将check检测需置为false,dubbo默认为true,为true(为无提供者时检测),若为true,则消费者启动是,引入的服务无法注入显示为空指针。

 (2)在启动类上,先扫描dubbo的引用,再启动配置类

 

微服务springboot集成dubbo采用注解的方式_第5张图片

到目前,代码块已全部编辑完,开始测试消费者调用生产者的功能,启动消费者,若显示一下信息,则注册成功。

微服务springboot集成dubbo采用注解的方式_第6张图片

同时我们也可以通过命令查看zk:ls /dubbo/com.comom.demo.service.UserService/consumers,若显示以下信息则表示成功。

最后接口测试:

微服务springboot集成dubbo采用注解的方式_第7张图片

 

你可能感兴趣的:(微服务springboot集成dubbo采用注解的方式)