dubbo原理和机制详解(非常全面)

mikechen的互联网架构 mikechen的互联网架构     2023-04-07     662

关键词:

Dubbo是一款Java RPC框架,致力于提供高性能的RPC远程服务调用方案。Dubbo 作为主流的微服务框架之一,为开发人员带来了非常多的便利。

本文我们重点详解 Dubbo 的原理机制 @mikechen

目录

1️⃣ Dubbo核心功能

Dubbo主要提供了3大核心功能:面向接口的远程方法调用,智能容错和负载均衡,以及服务自动注册和发现。

 1)远程方法调用

网络通信框架,提供对多种NIO框架抽象封装,包括“同步转异步”和“请求-响应”模式的信息交换方式。

 2)智能容错和负载均衡

提供基于接口方法的透明远程过程调用,包括多协议支持,以及软负载均衡,失败容错,地址路由,动态配置等集群支持。

3)服务注册和发现

服务注册,基于注册中心目录服务,使服务消费方能动态的查找服务提供方,使地址透明,使服务提供方可以平滑增加或减少机器。

2️⃣ Dubbo核心组件

Dubbo角色,主要包含如下几个核心组件:

1)注册中心(registry)

生产者在此注册并发布内容,消费者在此订阅并接收发布的内容。

2)消费者(consumer)

客户端,从注册中心获取到方法,可以调用生产者中的方法。

3)生产者(provider)

服务端,生产内容,生产前需要依赖容器(先启动容器)。

4)容器(container)

生产者在启动执行的时候,必须依赖容器才能正常启动(默认依赖的是spring容器),

5)监控(Monitor)

统计服务的调用次数与时间等。

3️⃣ Dubbo的架构设计

Dubbo整体架构如下图所示:

图中:

  • 左边(淡蓝背景):为服务消费方使用的接口
  • 右边(淡绿色背景):为服务提供方使用的接口
  • 位于中轴线上:为双方都用到的接口。

Dubbo 框架设计一共划分了10个层:

1. 服务接口层(Service)

该层是与实际业务逻辑相关的,根据服务提供方和服务消费方的业务设计对应的接口和实现。

2. 配置层(Config)

对外配置接口,以ServiceConfig和ReferenceConfig为中心,可以直接new配置类,也可以通过spring解析配置生成配置类。

 3.服务代理层(Proxy)

服务接口透明代理,生成服务的客户端Stub和服务器端Skeleton,以ServiceProxy为中心,扩展接口为ProxyFactory。

 4.服务注册层(Registry)

封装服务地址的注册与发现,以服务URL为中心,扩展接口为RegistryFactory、Registry和RegistryService。可能没有服务注册中心,此时服务提供方直接暴露服务。

 5.集群层(Cluster)

封装多个提供者的路由及负载均衡,并桥接注册中心,以Invoker为中心,扩展接口为Cluster、Directory、Router和LoadBalance。将多个服务提供方组合为一个服务提供方,实现对服务消费方来透明,只需要与一个服务提供方进行交互。

 6.监控层(Monitor)

RPC调用次数和调用时间监控,以Statistics为中心,扩展接口为MonitorFactory、Monitor和MonitorService。

 7.远程调用层(Protocol)

封将RPC调用,以Invocation和Result为中心,扩展接口为Protocol、Invoker和Exporter。Protocol是服务域,它是Invoker暴露和引用的主功能入口,它负责Invoker的生命周期管理。Invoker是实体域,它是Dubbo的核心模型,其它模型都向它靠扰,或转换成它,它代表一个可执行体,可向它发起invoke调用,它有可能是一个本地的实现,也可能是一个远程的实现,也可能一个集群实现。

8. 信息交换层(Exchange)

封装请求响应模式,同步转异步,以Request和Response为中心,扩展接口为Exchanger、ExchangeChannel、ExchangeClient和ExchangeServer。

 9.网络传输层(Transport)

抽象mina和netty为统一接口,以 Message 为中心,扩展接口为 Channel、Transporter、Client、Server和Codec。

10.数据序列化层(Serialize)

可复用的一些工具,扩展接口为 Serialization、 ObjectInput、ObjectOutput和ThreadPool。

4️⃣ Dubbo调用流程

对照上面的整体架构图,大致分为以下8大步骤:

1、服务提供者启动,开启Netty服务,创建Zookeeper客户端,向注册中心注册服务;

2、服务消费者启动,通过Zookeeper向注册中心获取服务提供者列表,与服务提供者通过Netty建立长连接;

3、服务消费者通过接口开始远程调用服务,ProxyFactory通过初始化Proxy对象,Proxy通过创建动态代理对象;

4、动态代理对象通过invoke方法,层层包装生成一个Invoker对象,该对象包含了代理对象;

5、Invoker通过路由,负载均衡选择了一个最合适的服务提供者,在通过加入各种过滤器,协议层包装生成一个新的DubboInvoker对象;

6、再通过交换成将DubboInvoker对象包装成一个Reuqest对象,该对象通过序列化通过NettyClient传输到服务提供者的NettyServer端;

7、到了服务提供者这边,再通过反序列化、协议解密等操作生成一个DubboExporter对象,再层层传递处理,会生成一个服务提供端的Invoker对象;

8、这个Invoker对象会调用本地服务,获得结果再通过层层回调返回到服务消费者,服务消费者拿到结果后,再解析获得最终结果。

以上,是关于 Dubbo 原理及机制的详细解析,可以作为 Dubbo 的参考学习资料,建议收藏、时常温顾。

如果觉得有用,请点击 点赞 + 转发 支持下,谢谢~

作者简介

陈睿 | mikechen,10年+大厂架构经验,「mikechen 的互联网架构」系列文章作者,专注互联网架构技术。

阅读「mikechen 的互联网架构」的更多技术文章:

Java并发 | JVM | MySQL | Spring | Redis | 分布式 | 高并发 

kafka架构和原理机制(图文全面详解)

...录一:Kafka简介二:Kafka基本架构三:Kafka基本原理特五:Kafka的特性六:Kafka的应用场景一:Kafka简介ApacheKafka是分布式发布-订阅消息系统,在kafka官网上对kafka的定义:一个分布式发布-订阅消息传递... 查看详情

kafka分区机制详解

...的性质原因,我需要大量接触Kafka,因此对Kafka的使用和原理都有一定的了解!这一期来聊聊Kafka非常非常重要的分区机制:主题与分区之间的关系✅分区工作的原理流程✅如何创建一个多分区的主题✅二、主题与分区在第一期的... 查看详情

dubbo的spi机制与jdk机制的不同及原理分析

从今天开始,将会逐步介绍关于DUbbo的有关知识。首先先简单介绍一下DUbbo的整体概述。概述Dubbo是SOA(面向服务架构)服务治理方案的核心框架。用于分布式调用,其重点在于分布式的治理。简单的来说,可以把它分为四个角色。... 查看详情

dubbo的配置过程,实现原理及架构详解

一.Dubbo是什么?Dubbo能做什么?随着互联网的发展,市场需求快速变更,业务持续高速增长,网站早已从单一应用架构演变为分布式服务架构及流动计算架构。在分布式架构的背景下,在本地调用非本进程内(远程)的资源就变... 查看详情

dubbo原理应用与面经总结(代码片段)

  研读dubbo源码已经有一段时间了,dubbo中有非常多优秀的设计模式和示例代码值得学习,但是dubbo的调用层级和方法链都较为繁杂,如果不对源码思路进行梳理则很容易忘却,因此总结一篇研读心得,从阅读源码的思路、... 查看详情

dubbo基本原理机制

client一个线程调用远程接口,生成一个唯一的ID(比如一段随机字符串,UUID等),Dubbo是使用AtomicLong从0开始累计数字的将打包的方法调用信息(如调用的接口名称,方法名称,参数值列表等)&#... 查看详情

dubbo原理和机制是啥?

dubbo原理和机制:应用可通过高性能的RPC实现服务的输出和输入功能,可以和Spring框架无缝集成。注册中心负责服务地址的注册与查找,相当于目录服务,服务提供者和消费者只在启动时与注册中心交互,注册中心不转发请求,... 查看详情

dubbo的底层实现原理和机制

参考技术ADubbo:是一个rpc框架,soa框架作为RPC:支持各种传输协议,如dubbo,hession,json,fastjson,底层采用mina,netty长连接进行传输!典型的provider和cusomer模式!作为SOA:具有服务治理功能,提供服务的注册和发现!用zookeeper实现注册中心... 查看详情

dubbo架构设计详解

Dubbo是Alibaba开源的分布式服务框架,它最大的特点是按照分层的方式来架构,使用这种方式可以使各个层之间解耦合(或者最大限度地松耦合)。从服务模型的角度来看,Dubbo采用的是一种非常简单的模型,要么是提供方提供服... 查看详情

并发编程的灵魂:cas机制详解(代码片段)

...作类来保证共享变量操作的原子性。这些原子操作的底层原理都是使用了CAS机制。在使用一门技术之前,了解这个技术的底层原理是非常重要的,所以本篇文章就先来讲讲什么是CAS机制,CAS机制存在的一些问题以及在Java中怎么... 查看详情

详解androidview中的事件分发机制(代码片段)

...是通过内部拦截和外部拦截法解决此类问题。要想搞明白原理就必须了解View的分发机制。在此之前我们先来了解一下以下三个非常重要的方法:dispatchTouchEvent()onInterceptTouchEvent()onTouchEvent()我们分别看看这三个方法:dispatc... 查看详情

详解androidview中的事件分发机制(代码片段)

...是通过内部拦截和外部拦截法解决此类问题。要想搞明白原理就必须了解View的分发机制。在此之前我们先来了解一下以下三个非常重要的方法:dispatchTouchEvent()onInterceptTouchEvent()onTouchEvent()我们分别看看这三个方法:dispatc... 查看详情

实例详解贝叶斯推理的原理

...60;       实例详解贝叶斯推理的原理姓名:余玥  学号:16010188033【嵌牛导读】:贝叶斯推理是由英国牧师贝叶斯发现的一种归纳推理方法,后来的许多研究者对贝叶斯方法在观点、方法和理论上... 查看详情

dubbo服务注册与动态发现机制的原理与实现细节

...调用器(Invoker)。以上就是Dubbo服务注册与动态发现机制的原理与实现细节。 查看详情

分布式技术专题「lvs负载均衡」全面透析web基础架构负载均衡lvs机制的原理分析指南

前提概要在大规模互联网应用中,负载均衡设备是必不可少的组成部分,源于互联网应用的高并发和大流量的冲击压力场景下,通常会在服务端部署多个无状态的应用服务器和若干有状态的存储服务器(数据库、缓存等等)实现... 查看详情

阿里面试必问的dubbo相关问题

...”,这个问题主要考察以下几个方面:你对RPC框架的底层原理掌握程度。以及考验你的整体RPC框架系统设计能力。具体,我来为大家详解。RPC和RPC框架1.RPC(RemoteProcedureCall)即远程过程调用,主要解决远程通信间的问题,不需要了解... 查看详情

dubbo中服务注册与发现实现原理(代码片段)

我们知道,现在一般微服务为了更好的管理都会提供对应的服务注册与服务发现机制,Dubbo作为一个RPC框架和微服务组件也提供了服务注册和服务发现机制,接下来我们看看Dubbo是怎么实现的服务注册我们还是基于之... 查看详情

精华推荐|mysql技术专题「主从同步架构」全面详细透析mysql的三种主从复制(replication)机制的原理和实战开发(原理+实战)(代码片段)

前提概要随着应用业务数据不断的增大,应用的响应速度不断下降,在检测过程中我们不难发现大多数的请求都是查询操作。此时,我们可以将数据库扩展成主从复制模式,将读操作和写操作分离开来,多台... 查看详情