dubbo概论

本文涉及的产品
网络型负载均衡 NLB,每月750个小时 15LCU
应用型负载均衡 ALB,每月750个小时 15LCU
传统型负载均衡 CLB,每月750个小时 15LCU
简介: dubbo概论

前言:

这可能是全网最深入浅出的dubbo文章,如果你会spring cloud,恭喜你,你可以在读这边博文的时候类比Spring Cloud,很快就能get到整个dubbo的关键点。如果你不会Spring Cloud也不要紧,这篇博文也能带你很快了解一下dubbo。

1.概述

dubbo,Alibaba推出的开源、高性能、轻量级的RPC框架。着力于提供两方面的能力:

  • 超高性能的RPC
  • 服务治理

超高性能的RPC:

首先dubbo兼容市面主流的通信协议,如HTTP等,其次dubbo自定义了通信协议,内置支持 Dubbo2、Triple 两款自定义的高性能通信协议,其高效率很重要的一部分就体现在自定义的通信协议上。

服务治理:

dubbo提供了一整套服务治理能力,涵盖:

  • 服务发现
  • 负载均衡
  • 路由
  • 链路追踪

等等

dubbo的架构:

在Dubbo中,dubbo会去接管服务的提供者和消费者,然后获取服务信息、调用服务都由dubbo来负责。正是因为负责了RPC过程,所以dubbo可以在通信过程种加入很多服务的治理能力进去。

2.服务发现

服务发现指的就是服务注册与发现的整个过程,dubbo支持常见的注册中心:


Nacos、Zookeeper、Consul、Redis


服务提供者会将自己的服务注册到注册中心,而服务消费者会从注册中心获取服务提供者的信息。为了减轻注册中心的负载并提高调用性能,Dubbo客户端会缓存从注册中心获取的服务提供者的地址列表或元数据信息。这样,在后续的服务调用过程中,Dubbo客户端可以直接使用本地缓存的信息,而无需每次都去注册中心查询。

7b4d906d14f3bde8a842ba4fb02f1858.png

Dubbo的缓存机制是提了高性能,减少了对注册中心的依赖,但同时也可能导致一些问题,例如服务提供者的地址发生变化时,如果缓存的信息没有及时更新,可能会导致调用失败或访问旧的服务提供者。因此,在使用Dubbo时,需要合理配置和管理缓存机制,以确保系统的可用性和一致性。


在Dubbo框架中,本地缓存和注册中心同步数据的时机是在以下情况下:

  1. 首次访问:当服务消费者首次访问某个服务时,Dubbo客户端会从注册中心获取服务提供者的地址列表或元数据信息,并将其缓存在本地。
  2. 缓存过期:Dubbo客户端可以配置缓存的过期时间。当缓存中的数据过期时,Dubbo会自动触发与注册中心的同步操作,更新本地缓存的服务注册信息。
  3. 强制刷新:在某些情况下,你可以通过配置选项或编程方式强制刷新本地缓存。例如,当服务提供者的地址发生变化,或者你希望立即获取最新的注册信息时,可以手动触发刷新操作。

dubbo种支持通过配置或者编码的方式来强制刷新缓存。此处不做代码或者配置上的展示,因为任何开源组件,其API或者配置属性都会随着版本的迭代改变,用的时候去官网查官方文档是最为稳妥的。


当然这里只聊了基础发布,dubbo其实还支持诸如灰度发布之类的高级的服务发布方式的,详见官方手册即可。

3.容错

3.1.注册中心宕机

dubbo存在本地缓存,注册中心宕机后,服务调用会走缓存,仍然不会影响使用。

3.2.负载均衡

Dubbo 提供的是客户端负载均衡,即由 Consumer 通过负载均衡算法得出需要将请求提交到哪个 Provider 实例。

提供了多种均衡策略:

默认为 weighted random基于权重的随机负载均衡策略。

算法 特性 备注
Weighted Random LoadBalance 加权随机 默认算法,默认权重相同
RoundRobin LoadBalance 加权轮询 借鉴于 Nginx 的平滑加权轮询算法,默认权重相同
LeastActive LoadBalance 最少活跃优先 + 加权随机 背后是能者多劳的思想
Shortest-Response LoadBalance 最短响应优先 + 加权随机 更加关注响应速度
ConsistentHash LoadBalance 一致性哈希 确定的入参,确定的提供者,适用于有状态请求
P2C LoadBalance Power of Two Choice 随机选择两个节点后,继续选择“连接数”较小的那个节点。
Adaptive LoadBalance 自适应负载均衡 在 P2C 算法基础上,选择二者中 load 最小的那个节点

以上所有负载均衡的具体代码、如何切换负载均衡策略等示例dubbo官网上的官方手册上都有详细说明,此处不做赘述。

3.3.限流、熔断

dubbo的限流和熔断通过集成第三方的组件来实现,如hystrix、Sentinel。要是又不会这两种流控组件的同学,正好博主之前有两篇优质的关于他们的文章,保证读一遍就懂:

详解Hystrix_hystrix版本__BugMan的博客-CSDN博客

详解sentinel使用_sentinel配置__BugMan的博客-CSDN博客

4.通信协议

4.1.HTTP

dubbo虽然自定义了应用层的通信协议,但是其还是支持HTTP的,具体的配置使用方法官方文档上有详细描述,此处不赘述。

4.2.dubbo

这里就是dubbo的重中之重,dubbo为什么被称为“高性能RPC框架”,很大一部分原因就是其自定义了一种高效的应用层通信协议——dubbo。

这里同学们可以先回想一下HTTP的报文结构,如果有不清楚的同学,可以移步博主的另一篇博客了解一下:

HTTP、HTTPS__BugMan的博客-CSDN博客

dubbo协议相比于HTTP来,其报文更加紧凑、简洁,具有更高的网络传输效率。

报文结构:

  1. 报文头部(Header):报文头部包含了一些元数据信息,例如魔数(Magic Number)、版本号、消息类型(请求或响应)、请求/响应ID等。这些信息用于Dubbo框架进行协议解析和消息处理。
  2. 报文体(Body):报文体包含了具体的请求或响应数据。对于请求消息,报文体中包含了调用的接口名称、方法名称、方法参数等。对于响应消息,报文体中包含了方法执行的结果、异常信息等。
  3. 序列化方式(Serialization):Dubbo报文的报文体中的数据需要进行序列化和反序列化操作。序列化方式定义了如何将Java对象转换为字节流以便在网络上传输,以及如何将字节流还原为Java对象。Dubbo框架支持多种序列化方式,例如Java自带的序列化、Hessian、JSON、Protobuf等。
  4. 消息编码(Codec):Dubbo报文在网络上传输时需要进行编码和解码操作。编码将报文数据转换为字节流,而解码将字节流还原为报文数据。Dubbo框架提供了多种编码方式,例如Dubbo协议的默认编码方式和其他自定义的编码方式。
  5. 扩展字段(Extensions):Dubbo报文还可以包含一些扩展字段,用于实现一些特定的功能或特性。例如,Dubbo报文可以通过扩展字段传递路由规则、负载均衡策略等信息。

5.总结

dubbo作为一款与spring cloud对标的产品,两者大的区别无非在两个方面:

  1. 生态
  2. 性能

1.生态:

生态上spring cloud是更加完善的,一套spring cloud全家桶,依赖引进来,啥组件都有了,而dubbo则需要自己去拼积木,对接第三方组件,拿组装电脑来类比的话,前者是水桶机,而后者是组装机,前者更方便开袋即食,后者更方便个性化定制。

2.性能:

在性能上dubbo是要优于spring cloud的,这也是dubbo立足的根本。dubbo的高性能主要体现在两点:

  • 选用netty作为容器
  • 自定义了报文结构

选用netty作为容器:

Dubbo底层其实是用netty来进行通信,netty的非阻塞式IO具有很高的性能。

自定义了报文结构:

netty自定义了通信协议,自定义了报文结构,比起http报文来,dubbo报文更加紧凑、简洁。其次,http报文的数据内容是文本格式的,而dubbo的数据内容是经过序列化的,dubbo报文的体积明显要小于http报文,解析速度、带宽利用率、吞吐量等指标上,dubbo明显都要由于http。

相关实践学习
SLB负载均衡实践
本场景通过使用阿里云负载均衡 SLB 以及对负载均衡 SLB 后端服务器 ECS 的权重进行修改,快速解决服务器响应速度慢的问题
负载均衡入门与产品使用指南
负载均衡(Server Load Balancer)是对多台云服务器进行流量分发的负载均衡服务,可以通过流量分发扩展应用系统对外的服务能力,通过消除单点故障提升应用系统的可用性。 本课程主要介绍负载均衡的相关技术以及阿里云负载均衡产品的使用方法。
目录
相关文章
|
8月前
|
Dubbo Cloud Native Java
干翻Dubbo系列第二篇:Dubbo3相对其他版本的升级
干翻Dubbo系列第二篇:Dubbo3相对其他版本的升级
|
2月前
|
负载均衡 监控 Dubbo
Dubbo 实现原理详解,一文吃透!
本文深入解析Dubbo的底层实现原理,涵盖远程方法调用、智能容错和负载均衡、服务注册和发现三大核心功能,详解其架构设计和调用流程。关注【mikechen的互联网架构】,10年+BAT架构经验倾囊相授。
Dubbo 实现原理详解,一文吃透!
|
3月前
|
Dubbo Java 应用服务中间件
Dubbo学习圣经:从入门到精通 Dubbo3.0 + SpringCloud Alibaba 微服务基础框架
尼恩团队的15大技术圣经,旨在帮助开发者系统化、体系化地掌握核心技术,提升技术实力,从而在面试和工作中脱颖而出。本文介绍了如何使用Dubbo3.0与Spring Cloud Gateway进行整合,解决传统Dubbo架构缺乏HTTP入口的问题,实现高性能的微服务网关。
|
8月前
|
XML Dubbo Java
【Dubbo3技术专题】回顾Dubbo2.x的技术原理和功能实现及源码分析(温故而知新)(二)
【Dubbo3技术专题】回顾Dubbo2.x的技术原理和功能实现及源码分析(温故而知新)
92 2
|
8月前
|
XML 监控 Dubbo
【Dubbo3技术专题】回顾Dubbo2.x的技术原理和功能实现及源码分析(温故而知新)(一)
【Dubbo3技术专题】回顾Dubbo2.x的技术原理和功能实现及源码分析(温故而知新)
117 1
|
Dubbo Java 应用服务中间件
由浅入深Dubbo网络通信协议大全
由浅入深Dubbo网络通信协议大全
142 0
|
8月前
|
Dubbo 应用服务中间件 Apache
干翻Dubbo系列第一篇:Dubbo是什么?
干翻Dubbo系列第一篇:Dubbo是什么?
|
缓存 监控 负载均衡
将近2万字的Dubbo原理解析,彻底搞懂dubbo
市面上有很多基于RPC思想实现的框架,比如有Dubbo。今天就从Dubbo的SPI机制、服务注册与发现源码及网络通信过程去深入剖析下Dubbo。
25854 9
|
XML 运维 Dubbo
Dubbo3 源码解读-宋小生-14:Dubbo配置加载全解析
> 完整电子书下载地址: https://developer.aliyun.com/ebook/7894 > Dubbo3 已经全面取代 HSF2 成为阿里的下一代服务框架,2022 双十一基于 Dubbo3 首次实现了关键业务不停推、不降级的全面用户体验提升,从技术上,大幅提高研发与运维效率的同时地址推送等关键资源利用率提升超 40%,基于三位一体的开源中间件体系打造了阿里在云上的单元化最佳实
239 0
Dubbo3 源码解读-宋小生-14:Dubbo配置加载全解析
|
存储 缓存 运维
Dubbo3 源码解读-宋小生-17:Dubbo服务提供者的双注册原理
> 完整电子书下载地址: https://developer.aliyun.com/ebook/7894 > Dubbo3 已经全面取代 HSF2 成为阿里的下一代服务框架,2022 双十一基于 Dubbo3 首次实现了关键业务不停推、不降级的全面用户体验提升,从技术上,大幅提高研发与运维效率的同时地址推送等关键资源利用率提升超 40%,基于三位一体的开源中间件体系打造了阿里在云上的单元化最佳实
468 0
Dubbo3 源码解读-宋小生-17:Dubbo服务提供者的双注册原理