SpringBoot集成org.apache.Dubbo
一、前言
Dubbo作为一款优秀的RPC框架,在国内有着众多的使用者,自从2018年2月,Dubbo被阿里捐献给Apache基金会以后,Dubbo似乎以全新的名称 Apache Dubbo焕发了新的生命力。虽然有着同样优秀和优势的Spring Clould框架,但是Dubbo能焕发新生也是一件好事,期待着Dubbo能够完善机制,更新迭代出的更好。
所有代码我已上传到github,需要的可以自取测试,欢迎start,传送门
https://github.com/AggerChen/spring-boot-dubbo
二、项目简介
在Dubbo新的官网上查看资料,虽然也有很多demo发现要不还是旧包名com.alibaba.dubbo,要不就是集成的SpringBoot1.x,根本没法满足新的需要嘛,既然都已经是Apache Dubbo了,当然要使用最新的org.apache.dubbo和最新的SpringBoot2.x版本了~
此篇文章就是以一下版本来展示示例:
SpringBoot 2.2.2
org.apache.dubbo 2.7.5
zookeeper 3.4.14
三、项目开发
既然是Dubbo项目,那么我们的使用场景就是分布式微服务,多个service和一个consumer,还需要一个公共项目common来编写公用的类与接口。
3.1 创建项目spring-boot-dubbo
- 在IDEA中创建一个project,取名spring-boot-dubbo。这是一个根项目,其中pom.xml包含依赖如下:
pom.xml
<?xml version="1.0" encoding="UTF-8"?>
<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.0</modelVersion>
<!-- 父级引用 -->
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.2.2.RELEASE</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
<!-- 基本信息 -->
<groupId>com.agger</groupId>
<artifactId>spring-boot-dubbo</artifactId>
<version>1.0.0-SNAPSHOT</version>
<packaging>pom</packaging>
<name>${project.artifactId}</name>
<description>dubbo根项目</description>
<!--配置-->
<properties>
<skip_maven_deploy>true</skip_maven_deploy>
<dubbo.version>2.7.5</dubbo.version>
<zookeeper.version>3.4.14</zookeeper.version>
<spring.version>5.2.2.RELEASE</spring.version>
<dubbo.common>0.0.1-SNAPSHOT</dubbo.common>
</properties>
<modules>
<module>dubbo-common</module>
<module>dubbo-consumer</module>
<module>dubbo-provider</module>
</modules>
<!--声明全局依赖(子项目需要显示的引用才会继承依赖)-->
<dependencyManagement>
<dependencies>
<!-- dubbo依赖 -->
<dependency>
<groupId>org.apache.dubbo</groupId>
<artifactId>dubbo</artifactId>
<version>${dubbo.version}</version>
<exclusions>
<exclusion>
<groupId>org.springframework</groupId>
<artifactId>spring</artifactId>
</exclusion>
<exclusion>
<groupId>javax.servlet</groupId>
<artifactId>servlet-api</artifactId>
</exclusion>
<exclusion>
<groupId>log4j</groupId>
<artifactId>log4j</artifactId>
</exclusion>
</exclusions>
</dependency>
<!-- dubbo-start依赖 -->
<dependency>
<groupId>org.apache.dubbo</groupId>
<artifactId>dubbo-spring-boot-starter</artifactId>
<version>${dubbo.version}</version>
</dependency>
<!-- zookeeper依赖 -->
<dependency>
<groupId>org.apache.zookeeper</groupId>
<artifactId>zookeeper</artifactId>
<version>${zookeeper.version}</version>
<exclusions>
<exclusion>
<artifactId>slf4j-log4j12</artifactId>
<groupId>org.slf4j</groupId>
</exclusion>
</exclusions>
</dependency>
<dependency>
<groupId>com.github.sgroschupf</groupId>
<artifactId>zkclient</artifactId>
<version>0.1</version>