头图

Dubbo是什么

Dubbo 是阿里巴巴公司开发的一款高性能的分布式服务框架,用于远程服务调用和服务治理。它具有透明化的远程调用、负载平衡、服务注册和发现、可扩展性和服务治理等特性。Dubbo支持自定义扩展各种功能,如负载均衡、协议、序列化等,并提供了大量服务治理功能,如监控、追踪、容错和限流等,让服务的运行更加稳定和可靠。它是一种高效、可扩展和可靠的分布式服务框架解决方案,适用于构建大型分布式系统。

image.png

Dubbo能做什么

Dubbo框架具有以下功能:

  1. 远程调用:Dubbo框架采用 RPC(远程过程调用)方式进行远程服务调用,在实现分布式系统中的服务调用时,可使调用者感觉就像是调用本地服务一样方便。
  2. 负载平衡:Dubbo框架内置多种负载平衡策略,可根据实际情况选择不同的负载平衡策略,如随机、轮询、最小活跃数等,使得服务请求可以平衡地分布到不同的服务提供者上,提高服务的可用性和性能。
  3. 服务注册和发现:Dubbo框架提供了服务注册和发现的功能,可将服务注册到注册中心,也可从注册中心中查询服务信息,方便实现服务的动态扩容和缩容。
  4. 可扩展性:Dubbo框架提供了可扩展的插件机制,可自定义扩展各种功能,如负载均衡、协议、序列化等。
  5. 服务治理:Dubbo框架提供了丰富的服务治理功能,如监控、追踪、容错和限流等,可使得服务的运行更加稳定和可靠。

Dubbo的架构

Dubbo框架主要由以下组件构成:

  1. Provider:发布服务并将服务注册到注册中心,等待消费者调用。
  2. Consumer:从注册中心订阅服务,和服务提供者进行通信,消费服务。
  3. Registry:记录服务提供者的信息,以及服务提供者和服务消费者之间的关系,帮助消费者发现可用的服务实例。
  4. Monitor:收集Dubbo节点的性能指标、服务调用统计信息等,以便运维人员进行监控和管理。
  5. Container:服务的运行容器。

image.png

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请求,填写对应名称、访问路径和请求方法。

image.png

2、接着我们到达运行页面,填入请求 body 的参数,传递参数的格式是:

{
   "jsonrpc": "2.0",
   "method": {{要调用的方法名称}},
   "params": {{方法所需的参数}},
   "id": {{请求的唯一标识符}}
}

所以我们填入正确格式的请求参数:

{
   "jsonrpc": "2.0",
   "method": "echo",
   "params": {
       "text": "Dubbo result"
   },
   "id": 18999
}

并且点击发送运行,得到 Dubbo 服务那边返回的数据。

3、点击发送运行按钮,得到Dubbo服务端返回的数据。

image.png

结论

Dubbo框架是一种高效、可扩展和可靠的分布式服务框架解决方案,它具有丰富的服务治理功能,并支持自定义扩展各种功能,适用于构建大型分布式系统。使用Apifox访问Dubbo服务只需简单的配置即可实现服务调用。更多关于Dubbo框架相关知识可点击下方链接了解。


Apifox
23 声望4 粉丝

Apifox 是 API 文档、API 调试、API Mock、API 自动化测试一体化平台。Apifox = Postman + Swagger + Mock + JMeter