springboot-zookeeper-dubbo 整合

springboot-zookeeper-dubbo

  1. 建议maven项目,pom.xml加上相应依赖

    	<parent>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-parent</artifactId>
            <version>2.3.3.RELEASE</version>
            <relativePath/> <!-- lookup parent from repository -->
        </parent>
    	<properties>
            <java.version>1.8</java.version>
        </properties>
        <dependencies>
            <dependency>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-starter</artifactId>
            </dependency>
            <dependency>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-starter-web</artifactId>
                <scope>compile</scope>
            </dependency>
            <!-- dubbo 相关依赖 -->
            <dependency>
                <groupId>org.apache.dubbo</groupId>
                <artifactId>dubbo-spring-boot-starter</artifactId>
                <version>2.7.8</version>
            </dependency>
            <dependency>
                <groupId>org.apache.curator</groupId>
                <artifactId>curator-recipes</artifactId>
                <version>2.13.0</version>
            </dependency>
            <dependency>
                <groupId>org.apache.zookeeper</groupId>
                <artifactId>zookeeper</artifactId>
                <version>3.4.13</version>
                <type>pom</type>
            </dependency>
        </dependencies>
    
  2. 建立一个Module 专门存放Consumer和provider 公用元素,可取名xxx-base模板,存放共同的接口和工具类等

  3. 建立Consumer对应的Module和Provider对应的Module,两者都引用base Module

    	<dependencies>
            <dependency>
                <groupId>com.baoyong</groupId>
                <artifactId>dubbo-base</artifactId>
                <version>${project.parent.version}</version>
            </dependency>
        </dependencies>
    
  4. 安装zookeeper,下载个压缩包本地解压修改一下conf/zoo.cfg即可,启动zk;

    1. 消费者 application配置:

      #Dubbo configuration
      dubbo.application.name=dubbo_consumer
      dubbo.registry.protocol=zookeeper
      dubbo.registry.address=zookeeper://127.0.0.1:2181
      # 注解中引用此版本,之后消费者可通过配置该参数实现动态切换引用的生产者
      dubbo.provider.version=2.0
      
    2. 生产者application配置:

      ## dubbo 配置
      dubbo.application.name=dubbo_provider
      dubbo.registry.protocol=zookeeper
      dubbo.registry.address=zookeeper://127.0.0.1:2181
      dubbo.protocol.name=dubbo
      dubbo.protocol.port=20880
      # 扫描注解包通过该设置将服务注册到zookeeper
      dubbo.scan.base-packages=com.baoyong.provider.service.impl
      
  5. 接口实现及调用:

    1. 在base的项目中定义接口 如 TestService。

    2. 在provider项目中实现base定义的接口,TestServiceImpl,注意引用注解:

      @DubboService(interfaceClass = TestService.class, interfaceName = "testServiceImplProvider", version = "${dubbo.provider.version}")
      public class TestServiceImpl implements TestService {
      	...
      }
      

      此处的实现类在bean容器中的id为 testServiceImpl

    3. 在consumer项目中引用provider的服务:

      @DubboReference(version = "${dubbo.provider.version}")
      private com.baoyong.base.service.TestService testService;
      
  6. 可配置不同version的provider,然后修改consumer调用provider的version即可切换不同版本调用。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值