Dubbo是什么
Dubbo 是阿里巴巴公司开发的一款高性能的分布式服务框架,用于远程服务调用和服务治理。它具有透明化的远程调用、负载平衡、服务注册和发现、可扩展性和服务治理等特性。Dubbo支持自定义扩展各种功能,如负载均衡、协议、序列化等,并提供了大量服务治理功能,如监控、追踪、容错和限流等,让服务的运行更加稳定和可靠。它是一种高效、可扩展和可靠的分布式服务框架解决方案,适用于构建大型分布式系统。
Dubbo能做什么
Dubbo框架具有以下功能:
- 远程调用:Dubbo框架采用 RPC(远程过程调用)方式进行远程服务调用,在实现分布式系统中的服务调用时,可使调用者感觉就像是调用本地服务一样方便。
- 负载平衡:Dubbo框架内置多种负载平衡策略,可根据实际情况选择不同的负载平衡策略,如随机、轮询、最小活跃数等,使得服务请求可以平衡地分布到不同的服务提供者上,提高服务的可用性和性能。
- 服务注册和发现:Dubbo框架提供了服务注册和发现的功能,可将服务注册到注册中心,也可从注册中心中查询服务信息,方便实现服务的动态扩容和缩容。
- 可扩展性:Dubbo框架提供了可扩展的插件机制,可自定义扩展各种功能,如负载均衡、协议、序列化等。
- 服务治理:Dubbo框架提供了丰富的服务治理功能,如监控、追踪、容错和限流等,可使得服务的运行更加稳定和可靠。
Dubbo的架构
Dubbo框架主要由以下组件构成:
- Provider:发布服务并将服务注册到注册中心,等待消费者调用。
- Consumer:从注册中心订阅服务,和服务提供者进行通信,消费服务。
- Registry:记录服务提供者的信息,以及服务提供者和服务消费者之间的关系,帮助消费者发现可用的服务实例。
- Monitor:收集Dubbo节点的性能指标、服务调用统计信息等,以便运维人员进行监控和管理。
- Container:服务的运行容器。
Dubbo的应用
下面是一个Dubbo的服务启动代码样例:
spring.dubbo.application.name=spring-boot-starter-dubbo-demo-consumer
spring.dubbo.registry.address=zookeeper: //localhost:2181
spring.dubbo.protocal.name=dubbo
spring.dubbo.protocol.port=20880
spring.dubbo.scan=com.sunlibin.weathercustomer
3.直接在serviceImpl层通过com.alibaba.dubbo.config.annotation.Reference;
package com.sunlibin.weathercustomer.service.impl;
import com.alibaba.dubbo.config.annotation.Reference;
import com.sunlibin.bean.District;
import com.sunlibin.service.RpcDistrictService;
import com.sunlibin.weathercustomer.service.DistrictService;
import org.springframework.stereotype.Service;
import java.util.List;
@Service("districtService")
public class DistrictServiceImpl implements DistrictService {
@Reference
private RpcDistrictService rpcDistrictService;
@Override
public List<District> getAllDistrict() {
return this.rpcDistrictService.getAllDistrict();
}
@Override
public District getDistrictById(Integer id) {
return this.rpcDistrictService.getDistrictById(id);
}
}
使用Apifox访问Dubbo服务
Dubbo其实就是RPC的一种远程调用方案,因此访问Dubbo服务可类比为调用RPC服务。我们需要使用API工具来进行接口的请求。以下是通过Apifox访问Dubbo服务的简要步骤:
1、在Apifox中新建Dubbo请求,填写对应名称、访问路径和请求方法。
2、接着我们到达运行页面,填入请求 body 的参数,传递参数的格式是:
{
"jsonrpc": "2.0",
"method": {{要调用的方法名称}},
"params": {{方法所需的参数}},
"id": {{请求的唯一标识符}}
}
所以我们填入正确格式的请求参数:
{
"jsonrpc": "2.0",
"method": "echo",
"params": {
"text": "Dubbo result"
},
"id": 18999
}
并且点击发送运行,得到 Dubbo 服务那边返回的数据。
3、点击发送运行按钮,得到Dubbo服务端返回的数据。
结论
Dubbo框架是一种高效、可扩展和可靠的分布式服务框架解决方案,它具有丰富的服务治理功能,并支持自定义扩展各种功能,适用于构建大型分布式系统。使用Apifox访问Dubbo服务只需简单的配置即可实现服务调用。更多关于Dubbo框架相关知识可点击下方链接了解。
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。