非常全面 Dubbo 原理和机制详解


非常全面 Dubbo 原理和机制详解

文章插图
Dubbo 是一款Java RPC框架 , 致力于提供高性能的 RPC 远程服务调用方案 。作为主流的微服务框架之一 , Dubbo 为开发人员带来了非常多的便利 。
大家好 , 我是 mikechen , 专注分享「互联网大厂架构技术」~
本文 , 我重点详解 Dubbo 的原理机制 @mikechen
目录
  • Dubbo核心功能
  • Dubbo核心组件
  • Dubbo的架构设计
  • Dubbo调用流程
Dubbo核心功能Dubbo主要提供了3大核心功能:面向接口的远程方法调用 , 智能容错和负载均衡 , 以及服务自动注册和发现 。
 1)远程方法调用
网络通信框架 , 提供对多种NIO框架抽象封装 , 包括“同步转异步”和“请求-响应”模式的信息交换方式 。
 2)智能容错和负载均衡
提供基于接口方法的透明远程过程调用 , 包括多协议支持 , 以及软负载均衡 , 失败容错 , 地址路由 , 动态配置等集群支持 。
3)服务注册和发现
服务注册 , 基于注册中心目录服务 , 使服务消费方能动态的查找服务提供方 , 使地址透明 , 使服务提供方可以平滑增加或减少机器 。
Dubbo核心组件Dubbo角色 , 主要包含如下几个核心组件:
非常全面 Dubbo 原理和机制详解

文章插图
1)注册中心(registry)
生产者在此注册并发布内容 , 消费者在此订阅并接收发布的内容 。
2)消费者(consumer)
客户端 , 从注册中心获取到方法 , 可以调用生产者中的方法 。
3)生产者(provider)
服务端 , 生产内容 , 生产前需要依赖容器(先启动容器) 。
4)容器(container)
生产者在启动执行的时候 , 必须依赖容器才能正常启动(默认依赖的是spring容器) , 
5)监控(Monitor)
统计服务的调用次数与时间等 。
Dubbo的架构设计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 。将多个服务提供方组合为一个服务提供方 , 实现对服务消费方来透明 , 只需要与一个服务提供方进行交互 。

经验总结扩展阅读