Dubbo源码分析:小白入门篇

如果你已经对Dubbo熟练使用了,那这篇文章不太适合你,但如果想了解Dubbo,想学习Dubbo,那就非常适合你。

Dubbo源码分析:小白入门篇

什么是Dubbo?

Dubbo一开始是由阿里巴巴开发,后面贡献给了Apache,所以后面我们称之为Apache Dubbo或者直接叫Dubbo

Dubbo 是一款高性能、轻量级的开源服务框架 。

先纠正读法:

错误读法:diubo、dubo

正确读法:|ˈdʌbəʊ|

Dubbo的六大核心能力

  • 面向接口代理的高性能RPC调用
  • 智能容错和负载均衡
  • 服务自动注册和发现
  • 高度可扩展能力
  • 运行期流量调度
  • 可视化的服务治理与运维。

开发中,我们都喜欢把Dubbo简称为RPC开源框架。

什么是RPC?

RPCRemote Procedure Call的简称,翻译过来就是:远程过程调用

简单的理解是一个节点请求另一个节点提供的服务 。

通俗点讲:

两台服务器A和B,在服务器A上部署一个应用程序serverA,在服务器B上部署一个应用程序serverB。此时,serverA想调用serverB里的某个方法,由于不在同一服务器内,不能直接调用,需要通过网络来表达调用的语义和传导调用的数据。

调用远程的方法就像调用本地的方法一样。

Dubbo源码分析:小白入门篇

我们开发中,通常两个服务(不同服务器上的服务)之间的调用,通常都是用HTTP REST。

RPC框架

其实关于RPC框架,市面上有很多了,Dubbo只是其中之一。比如说还有:

  • gRPC 是 Google 开发的高性能、通用的开源 RPC 框架,gRPC 使用 ProtoBuf 来定义服务,ProtoBuf 是 Google 开发的一种数据序列化协议,性能比较高,压缩和传输效率高,语法也比较简单。另外,gRPC 支持多种语言,并能够基于语言自动生成客户端和服务端功能库。
  • Thrift 起源于 Facebook,和 Dubbo 一样,后来被提交 Apache 基金会将 Thrift 作为一个开源项目。Facebook 创造 Thrift 的目的是为了解决 Facebook 各系统间大数据量的传输通信,以及系统间语言环境不同需要跨平台的问题。
  • Motan 是新浪微博开源的一个 Java RPC 框架,官方文档对外宣传在微博平台已经广泛应用,每天为数百个服务完成近千亿次的调用。
  • ...

Dubbo核心角色

我们来看看Dubbo架构中的核心角色:

Dubbo源码分析:小白入门篇

该图来自于官网,下面我们对图做一个简单介绍:

Registry

注册中心。负责服务地址的注册与查找,服务的 ProviderConsumer 只在启动时与注册中心交互。注册中心通过长连接感知 Provider 的存在,在 Provider 出现宕机的时候,注册中心会立即推送相关事件通知 Consumer

Provider

服务提供者。在它启动的时候,会向 Registry 进行注册操作,将自己服务的地址和相关配置信息封装成 URL 添加到 ZooKeeper 中。

Consumer

服务消费者。在它启动的时候,会向 Registry 进行订阅操作。订阅操作会从 ZooKeeper 中获取 Provider 注册的 URL,并在 ZooKeeper 中添加相应的监听器。获取到 Provider URL 之后,Consumer 会根据负载均衡算法从多个 Provider 中选择一个 Provider 并与其建立连接,最后发起对 ProviderRPC 调用。如果 Provider URL 发生变更,Consumer 将会通过之前订阅过程中在注册中心添加的监听器,获取到最新的 Provider URL 信息,进行相应的调整,比如断开与宕机 Provider 的连接,并与新的 Provider 建立连接。Consumer 与 Provider 建立的是长连接,且 Consumer 会缓存 Provider 信息,所以一旦连接建立,即使注册中心宕机,也不会影响已运行的 ProviderConsumer

Monitor

监控中心。用于统计服务的调用次数和调用时间。ProviderConsumer 在运行过程中,会在内存中统计调用次数和调用时间,定时每分钟发送一次统计数据到监控中心。监控中心在上面的架构图中并不是必要角色,监控中心宕机不会影响 ProviderConsumer 以及 Registry 的功能,只会丢失监控数据而已。

猥琐发育,后期爆发,(前期可能关注的不多,但是后期它特别香)

Container:

服务运行容器。是一个独立的容器,因为服务通常不需要TomcatJBoss等Web容器的特性,没必要用Web容器去加载服务。服务容器只是一个简单的main方法,并加载一个简单的Spring容器,用于暴露服务。

流程说明

在上面这张图中,有几个角色,并且还画了很多线条,下面我们对此做一个简单说明。

  • 服务容器负责启动,加载,运行服务提供者。
  • 服务提供者在启动时,向注册中心注册自己提供的服务。
  • 服务消费者在启动时,向注册中心订阅自己所需的服务。
  • 注册中心返回服务提供者地址列表给消费者,如果有变更,注册中心将基于长连接推送变更数据给消费者。
  • 服务消费者,从提供者地址列表中,基于软负载均衡算法,选一台提供者进行调用,如果调用失败,再选另一台调用。
  • 服务消费者和提供者,在内存中累计调用次数和调用时间,定时每分钟发送一次统计数据到监控中心。

Dubbo官网

Dubbo的官网:https://dubbo.apache.org/

Dubbo源码分析:小白入门篇

由于Dubbo是由阿里巴巴技术团队开发的,所以,文档方面对于咱们中国人来说那是相当的友好,一个字:爽!

另外,Dubbo官网上很多东西,我们就不在这里一一介绍了。

建议大家都去官网逛逛。

话不多说,咱们先来嗨一把!

demo案例1

我们先来搞一个没有注册中心的案例。

我们搭建一个项目,并创建三个module

  • dubbo-demo
  • dubbo-demo-api
  • dubbo-demo-provider
  • dubbo-demo-consumer

项目整体结构如下:

Dubbo源码分析:小白入门篇

下面,我们来代码做一个简单说明。

首先是pom依赖:

org.apache.dubbo dubbo 3.0.4 com.tian.dubbo dubbo-demo-api 1.0-SNAPSHOT 登录后复制