SpringBoot集成Dubbo:Case
1、什么是Duubo?
Dubbo是一款高性能的,由阿里巴巴开发的一款RPC远程调用框架
,已交由apache组织进行维护。他使得应用可通过高性能的 RPC 实现服务的输出和输入功能,可以和 [1] Spring框架无缝集成。
官方网址:https://dubbo.apache.org/zh/
2、概念架构
2.1 提供者
provider:即在分布式的服务中,真正实现业务的组件。简单讲就是提供服务的
2.2 消费者
consumer:即在分布式的服务中,调用业务逻辑的组件。消费提供者提供的服务的
2.3 注册中心
registry:用于监听提供者所提供的服务变化等。Dubbo的四种主要的注册中心:
- ZooKeeper
- Redis
- Simple
- Multicast
3、SpringBoot集成Dubbo步骤
- 注册中心
- 服务提供者
- 服务消费者
- 服务公共组件
1️⃣准备注册中心
这里使用的zookeeper注册中心,安装自行去网上搜有很多,这里不再赘述,安装好后,开启zookeeper注册中心。
2️⃣准备服务的公共组件
公共组件这里采用的是普通的maven项目,主要定义一些实体类和公共接口
model
private Integer id;
private String name;
private Integer age;
service
Student queryById(Integer id);
3️⃣准备一个提供者的组件
这里使用SpringBoot来创建,目录结构如下所示:
在提供者的组件中,首先先引入依赖
- 公共组件的依赖
- dubbo的依赖
- zookeeper的依赖
注意
在引入zookeeper的依赖的时候,需要排除log4j所引发的重复引入的错误
<dependencies>
<!-- 引入公共依赖项 -->
<dependency>
<groupId>com.wei</groupId>
<artifactId>DHC_DubboProject-common</artifactId>
<version>1.0.0</version>
</dependency>
<!-- 引入dubbo的依赖 -->
<!-- https://mvnrepository.com/artifact/org.apache.dubbo/dubbo-spring-boot-starter -->
<dependency>
<groupId>org.apache.dubbo</groupId>
<artifactId>dubbo-spring-boot-starter</artifactId>
<version>2.7.8</version>
</dependency>
<!-- zookeeper依赖 -->
<!-- https://mvnrepository.com/artifact/org.apache.dubbo/dubbo-dependencies-zookeeper -->
<dependency>
<groupId>org.apache.dubbo</groupId>
<artifactId>dubbo-dependencies-zookeeper</artifactId>
<version>2.7.8</version>
<type>pom</type>
<exclusions>
<exclusion>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-log4j12</artifactId>
</exclusion>
</exclusions>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
</dependencies>
然后完成业务的实现
@Component
@DubboService(interfaceClass = IStudentService.class,version = "1.0")
public class StudentServiceImpl implements IStudentService{
/**
* 提供服务的方法
*/
@Override
public Student queryById(Integer id) {
Student student = new Student();
if (1001==id) {
student.setAge(21);
student.setId(id);
student.setName("张三");
}else if (1002==id) {
student.setAge(22);
student.setId(id);
student.setName("李四");
}
return student;
}
}
使用注解使用注解@DubboService:来指定其具体所实现的业务接口的类及版本等
配置文件
# 配置服务名称
spring:
application:
name: StudentService-provider
# 配置扫描的包
dubbo:
scan:
base-packages: com.wei.service
# 配置dubbo协议
# protocol:
# name: dubbo
# port: 20881
registry:
address: zookeeper://localhost:2181
4️⃣完成消费者组件
消费者与提供者所依赖的包都基本一样,所以直接拷贝提供者的依赖文件
controller测试
@RestController
public class DubboController {
/**
* 引用远程服务 把创建好的远程服务注入给消费者
*/
@DubboReference(interfaceClass = IStudentService.class,version = "1.0")
private IStudentService service;
@PostMapping("/queryById/{id}")
public Student queryById(@PathVariable("id") Integer id) {
Student student = service.queryById(id);
return student;
}
}
配置文件
# 指定服务名称
server:
port: 8081
spring:
application:
name: consumer-application
# 指定注册中心
dubbo:
registry:
address: zookeeper://localhost:2181
4、测试
- 启动zookeeper
- 启动提供者服务
- 启动消费者服务
- postman测试
成功!!!
总结
Dubbo注解:
@DubboService:在提供者端使用,暴露服务的,放在接口的实现类上面
@Dubboreference:在消费者端使用,引用服务的,放在属性上面,用于注入服务的引用接口。
@EableDubbo:放在主程序类上面,表示当前引用启用Dubbo功能。