springboot-zookeeper-dubbo
-
建议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>
-
建立一个Module 专门存放Consumer和provider 公用元素,可取名xxx-base模板,存放共同的接口和工具类等
-
建立Consumer对应的Module和Provider对应的Module,两者都引用base Module
<dependencies> <dependency> <groupId>com.baoyong</groupId> <artifactId>dubbo-base</artifactId> <version>${project.parent.version}</version> </dependency> </dependencies>
-
安装zookeeper,下载个压缩包本地解压修改一下conf/zoo.cfg即可,启动zk;
-
消费者 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
-
生产者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
-
-
接口实现及调用:
-
在base的项目中定义接口 如 TestService。
-
在provider项目中实现base定义的接口,TestServiceImpl,注意引用注解:
@DubboService(interfaceClass = TestService.class, interfaceName = "testServiceImplProvider", version = "${dubbo.provider.version}") public class TestServiceImpl implements TestService { ... }
此处的实现类在bean容器中的id为 testServiceImpl
-
在consumer项目中引用provider的服务:
@DubboReference(version = "${dubbo.provider.version}") private com.baoyong.base.service.TestService testService;
-
-
可配置不同version的provider,然后修改consumer调用provider的version即可切换不同版本调用。