• SpringBoot整合Alibaba-Dubbo和Apache-Dubbo



    由于dubbo起初是阿里开发,后来交给了apache维护,所以市场上就有两个版本的dubbo整合

    1 Alibaba整合Dubbo

    1.1 服务提供者

    1.1.1 服务提供者接口

    项目结构图
    在这里插入图片描述
    pom.xm

       <groupId>cn.jzhgroupId>
        <artifactId>dubbo-serviceartifactId>
        <version>1.0-SNAPSHOTversion>
    
        <properties>
            <maven.compiler.source>8maven.compiler.source>
            <maven.compiler.target>8maven.compiler.target>
        properties>
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8

    接口类

    public interface DemoService {
        public String test (String msg);
    }
    
    • 1
    • 2
    • 3

    1.1.2 服务提供者实现类

    1.1.2.1 项目结构图

    在这里插入图片描述

    1.1.2.2 pom.xml
    
    <project xmlns="http://maven.apache.org/POM/4.0.0"
             xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
             xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
        <modelVersion>4.0.0modelVersion>
        <groupId>cn.jzhgroupId>
        <artifactId>dubbo-service-alibaba-implartifactId>
        <version>1.0-SNAPSHOTversion>
    
        <parent>
            <groupId>org.springframework.bootgroupId>
            <artifactId>spring-boot-starter-parentartifactId>
            <version>2.6.6version>
        parent>
    
        <properties>
            <maven.compiler.source>8maven.compiler.source>
            <maven.compiler.target>8maven.compiler.target>
        properties>
    
    
        <dependencies>
            
            <dependency>
                <groupId>cn.jzhgroupId>
                <artifactId>dubbo-serviceartifactId>
                <version>1.0-SNAPSHOTversion>
            dependency>
            
            <dependency>
                <groupId>org.springframework.bootgroupId>
                <artifactId>spring-boot-starter-webartifactId>
            dependency>
    
            
            <dependency>
                <groupId>com.alibaba.spring.bootgroupId>
                <artifactId>dubbo-spring-boot-starterartifactId>
                <version>2.0.0version>
            dependency>
    
            
            <dependency>
                <groupId>com.101tecgroupId>
                <artifactId>zkclientartifactId>
                <version>0.10version>
                
                <exclusions>
                    <exclusion>
                        <groupId>log4jgroupId>
                        <artifactId>log4jartifactId>
                    exclusion>
                    <exclusion>
                        <groupId>org.slf4jgroupId>
                        <artifactId>slf4j-apiartifactId>
                    exclusion>
                    <exclusion>
                        <groupId>org.slf4jgroupId>
                        <artifactId>slf4j-log4j12artifactId>
                    exclusion>
                exclusions>
            dependency>
        dependencies>
    project>
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
    • 43
    • 44
    • 45
    • 46
    • 47
    • 48
    • 49
    • 50
    • 51
    • 52
    • 53
    • 54
    • 55
    • 56
    • 57
    • 58
    • 59
    • 60
    • 61
    • 62
    • 63
    • 64
    1.1.2.3 服务实现类
    import cn.jzh.service.DemoService;
    import com.alibaba.dubbo.config.annotation.Service;
    import org.springframework.stereotype.Component;
    
    
    @Component
    // @Service 这个注解使用的不是spring里面的,而是com.alibaba.dubbo.config.annotation.Service。
    // timeout 配置超时时间 , interfaceClass 接口类 ,version 服务版本,如果配置了服务版本在消费端引用也必须一样
    @Service(timeout = 1000,interfaceClass = DemoService.class)
    public class DemoAlibabaServiceImpl implements DemoService {
        @Override
        public String test(String msg) {
            return "dubbo接收信息"+msg;
        }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    1.1.2.4 配置文件

    application.properties

    server.port=8081
    server.servlet.context-path=/
    
    spring.application.name=spingboot-alibaba-provider
    
    #设置dubbo的配置
    dubbo.application.name=springboot-alibaba-provider
    # 注册中心
    dubbo.registry.address=zookeeper://127.0.0.1:2181
    dubbo.protocol.name=dubbo
    dubbo.protocol.port=20881
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    1.1.2.5 启动类
    import com.alibaba.dubbo.config.spring.context.annotation.DubboComponentScan;
    import com.alibaba.dubbo.config.spring.context.annotation.EnableDubbo;
    import com.alibaba.dubbo.spring.boot.annotation.EnableDubboConfiguration;
    import org.springframework.boot.SpringApplication;
    import org.springframework.boot.autoconfigure.SpringBootApplication;
    
    @SpringBootApplication
    @EnableDubbo // 启动dubbo功能
    @EnableDubboConfiguration // 启动dubbo配置
    @DubboComponentScan("cn.jzh.service.impl") // 扫描提供者实现类
    public class AppAlibaba {
            public static void main(String[] args) {
                SpringApplication.run(AppAlibaba.class,args);
            }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15

    1.2 服务消费者

    1.2.1 项目结构图示

    在这里插入图片描述

    提供者和消费者的pom.xml一样,所以就不在此处写pom.xml

    1.2.2 请求入口

    import cn.jzh.service.DemoService;
    import com.alibaba.dubbo.config.annotation.Reference;
    import org.springframework.stereotype.Controller;
    import org.springframework.web.bind.annotation.RequestMapping;
    import org.springframework.web.bind.annotation.RestController;
    
    @RestController
    public class DemoController {
    
        // 在这里是使用@Reference去发现服务而不是@Autowired去注入Bean,@Reference里面可以配置version、timeout超时时间
        @Reference
        private DemoService demoService;
    
        @RequestMapping("/test")
        public String findAllStudent(){
            return demoService.test("测试结果");
        }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18

    1.2.3 配置文件

    application.properties

    server.port=8082
    server.servlet.context-path=/
    
    spring.application.name=spingboot-alibaba-consumer
    
    #设置dubbo的配置
    dubbo.application.name=springboot-alibaba-consumer
    # 注册中心
    dubbo.registry.address=zookeeper://127.0.0.1:2181
    dubbo.protocol.name=dubbo
    dubbo.protocol.port=20881
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11

    1.2.4 启动类

    import com.alibaba.dubbo.config.spring.context.annotation.DubboComponentScan;
    import com.alibaba.dubbo.config.spring.context.annotation.EnableDubbo;
    import com.alibaba.dubbo.spring.boot.annotation.EnableDubboConfiguration;
    import org.springframework.boot.SpringApplication;
    import org.springframework.boot.autoconfigure.SpringBootApplication;
    
    @SpringBootApplication
    @EnableDubbo
    @EnableDubboConfiguration
    public class AppAlibabaConsumer {
        public static void main(String[] args) {
            SpringApplication.run(AppAlibabaConsumer.class,args);
        }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14

    2 Apache整合Dubbo

    2.1 服务提供者

    2.1.1 服务提供者接口

    项目结构图
    在这里插入图片描述
    pom.xm

       <groupId>cn.jzhgroupId>
        <artifactId>dubbo-serviceartifactId>
        <version>1.0-SNAPSHOTversion>
    
        <properties>
            <maven.compiler.source>8maven.compiler.source>
            <maven.compiler.target>8maven.compiler.target>
        properties>
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8

    接口类

    public interface DemoService {
        public String test (String msg);
    }
    
    • 1
    • 2
    • 3

    2.1.2 服务提供者实现类

    2.1.2.1 项目结构图

    在这里插入图片描述

    2.1.2.2 pom.xml
    
    <project xmlns="http://maven.apache.org/POM/4.0.0"
             xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
             xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
        <modelVersion>4.0.0modelVersion>
    
        <parent>
            <groupId>org.springframework.bootgroupId>
            <artifactId>spring-boot-starter-parentartifactId>
            <version>2.6.6version>
        parent>
    
        <groupId>cn.jzhgroupId>
        <artifactId>dubbo-service-apache-implartifactId>
        <version>1.0-SNAPSHOTversion>
    
        <properties>
            <maven.compiler.source>8maven.compiler.source>
            <maven.compiler.target>8maven.compiler.target>
        properties>
        <dependencies>
            
            <dependency>
                <groupId>cn.jzhgroupId>
                <artifactId>dubbo-serviceartifactId>
                <version>1.0-SNAPSHOTversion>
            dependency>
            
            <dependency>
                <groupId>org.springframework.bootgroupId>
                <artifactId>spring-boot-starter-webartifactId>
            dependency>
    
            
            <dependency>
                <groupId>org.apache.dubbogroupId>
                <artifactId>dubbo-spring-boot-starterartifactId>
                <version>3.1.2version>
            dependency>
            
    
            
            <dependency>
                <groupId>org.apache.zookeepergroupId>
                <artifactId>zookeeperartifactId>
                <version>3.4.13version>
                <exclusions>
                    <exclusion>
                        <artifactId>slf4j-log4j12artifactId>
                        <groupId>org.slf4jgroupId>
                    exclusion>
                exclusions>
            dependency>
            <dependency>
                <groupId>com.github.sgroschupfgroupId>
                <artifactId>zkclientartifactId>
                <version>0.1version>
            dependency>
            <dependency>
                <groupId>org.apache.curatorgroupId>
                <artifactId>curator-recipesartifactId>
                <version>4.2.0version>
            dependency>
            <dependency>
                <groupId>org.apache.curatorgroupId>
                <artifactId>curator-frameworkartifactId>
                <version>4.2.0version>
            dependency>
            <dependency>
                <groupId>org.apache.curatorgroupId>
                <artifactId>curator-x-discoveryartifactId>
                <version>4.2.0version>
            dependency>
        dependencies>
    project>
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
    • 43
    • 44
    • 45
    • 46
    • 47
    • 48
    • 49
    • 50
    • 51
    • 52
    • 53
    • 54
    • 55
    • 56
    • 57
    • 58
    • 59
    • 60
    • 61
    • 62
    • 63
    • 64
    • 65
    • 66
    • 67
    • 68
    • 69
    • 70
    • 71
    • 72
    • 73
    • 74
    • 75
    2.1.2.3 服务实现类

    在新版apache-dubbodubbo提供者注解@Service提示为过时,推荐使用注解@DubboService

    package cn.jzh.service.impl;
    
    import cn.jzh.service.DemoService;
    import org.apache.dubbo.config.annotation.DubboService;
    import org.springframework.stereotype.Component;
    
    @Component
    @DubboService
    public class DemoApacheServiceImpl implements DemoService {
        @Override
        public String test(String msg) {
            return "dubbo接收信息"+msg;
        }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    2.1.2.4 配置文件

    application.properties

    server.port=8083
    server.servlet.context-path=/
    
    spring.application.name=spingboot-apache-provider
    #设置dubbo的配置
    dubbo.application.name=springboot-apache-provider-dubbo
    # 注册中心
    dubbo.registry.address=zookeeper://127.0.0.1:2181
    dubbo.registry.protocol=zookeeper
    dubbo.protocol.name=dubbo
    dubbo.protocol.port=20881
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    2.1.2.5 启动类
    package cn.jzh;
    
    import org.apache.dubbo.config.spring.context.annotation.DubboComponentScan;
    import org.apache.dubbo.config.spring.context.annotation.EnableDubbo;
    import org.springframework.boot.SpringApplication;
    import org.springframework.boot.autoconfigure.SpringBootApplication;
    
    @EnableDubbo
    @SpringBootApplication
    @DubboComponentScan("cn.jzh.service.impl")//用来扫描提供的接口实现位置
    public class AppApache {
    
        public static void main(String[] args) {
            SpringApplication.run(AppApache.class,args);
        }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16

    2.2 服务消费者

    2.2.1 项目结构图示

    在这里插入图片描述

    提供者和消费者的pom.xml一样,所以就不在此处写pom.xml

    2.2.2 请求入口

    在新版apache-dubbodubbo提供者注解@Reference提示为过时,推荐使用注解@DubboReference

    package cn.jzh.contoller;
    
    import cn.jzh.service.DemoService;
    import org.apache.dubbo.config.annotation.DubboReference;
    import org.springframework.web.bind.annotation.RequestMapping;
    import org.springframework.web.bind.annotation.RestController;
    
    @RestController
    public class DemoController {
      
        @DubboReference
        private DemoService demoService;
        @RequestMapping("/test")
        public String findAllStudent(){
            return demoService.test("测试结果");
        }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17

    2.2.3 配置文件

    application.properties

    server.port=8084
    server.servlet.context-path=/
    
    spring.application.name=spingboot-apache-consumer
    
    #设置dubbo的配置
    dubbo.application.name=springboot-apache-consumer-dubbo
    # 注册中心
    dubbo.registry.address=zookeeper://127.0.0.1:2181
    dubbo.registry.protocol=zookeeper
    dubbo.protocol.name=dubbo
    dubbo.protocol.port=20881
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12

    2.2.4 启动类

    package cn.jzh;
    
    import org.apache.dubbo.config.spring.context.annotation.EnableDubbo;
    import org.springframework.boot.SpringApplication;
    import org.springframework.boot.autoconfigure.SpringBootApplication;
    
    @SpringBootApplication
    @EnableDubbo
    public class AppApacheConsumer {
        public static void main(String[] args) {
            SpringApplication.run(AppApacheConsumer.class,args);
        }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
  • 相关阅读:
    用Python编写自己的微型Redis
    金九银十已到,大厂面试大全+面试经历都在这了(建议收藏)
    uniapp获取接口数据并渲染至页面中
    良许翻天覆地的2022年
    Windows控制台ssh连接Linux,并且保持连接不断开
    Uniapp vue2 和 Vue3 的 生命周期
    在pycharm中配置nodejs
    【云原生 | Docker 基础篇】06、本地镜像发布到阿里云
    antd的Table组件使用rowSelection属性实现多选时遇到的bug
    文献 | 越想快乐,越不快乐
  • 原文地址:https://blog.csdn.net/u012060033/article/details/128043864