dubbo源码系列1-总架构

dubbo架构

dubbo是阿里集团开源的一个非常出名的RPC框架,在很多互联网公司和企业应用中广泛使用。协议和序列化框架都可以插拔是及其鲜明的特色。远程接口是基于Java Interface,并且依托于spring框架管理bean,开发非常方便。

dubbo 最重要的五个核心模块:provider(提供者)、registry(注册中心)、consumer(消费者)、monitor(监控)和 container(服务运行容器)

架构图如下:

container:服务容器负责启动,加载,运行服务提供者

registry: provider在启动时,向 registry 注册自己提供的服务。而 consumer 在启动时向 registry 订阅自己所需要的服务

provider: provider在启动时,向 registry 注册自己提供的服务

consumer:registry 返回 provider 地址列表给 consumer,如果有变更,registry将基于长连接推送变更数据给consumer。consumer 从 provider 地址列表中,基于软负载均衡算法,选一台提供者进行调用,如果调用失败,再选另一台调用

monitor: provider 和 consumer 在内存中累计调用次数和调用时间,定时每分钟发送一次统计数据到监控中心

dubbo 特点

dubbo 架构具有特点:连通性、健壮性、伸缩性

连通性

扫描二维码关注公众号,回复: 12601825 查看本文章

1、注册中心负责服务地址的注册与查找,相当于目录服务,服务提供者和消费者只在启动时与注册中心交互,注册中心不转发请求,压力较小

2、监控中心负责统计各服务调用次数,调用时间等,统计先在内存汇总后每分钟一次发送到监控中心服务器,并以报表展示

3、服务提供者向注册中心注册其提供的服务,并汇报调用时间到监控中心,此时间不包含网络开销

4、服务消费者向注册中心获取服务提供者地址列表,并根据负载算法直接调用提供者,同时汇报调用时间到监控中心,此时间包含网络开销

5、注册中心,服务提供者,服务消费者三者之间均为长连接,监控中心除外

6、注册中心通过长连接感知服务提供者的存在,服务提供者宕机,注册中心将立即推送事件通知消费者

7、注册中心和监控中心全部宕机,不影响已运行的提供者和消费者,消费者在本地缓存了提供者列表

8、注册中心和监控中心都是可选的,服务消费者可以直连服务提供者

健壮性

1、监控中心宕掉不影响使用,只是丢失部分采样数据

2、数据库宕掉后,注册中心仍能通过缓存提供服务列表查询,但不能注册新服务

3、注册中心对等集群,任意一台宕掉后,将自动切换到另一台

4、注册中心全部宕掉后,服务提供者和服务消费者仍能通过本地缓存通讯

5、服务提供者无状态,任意一台宕掉后,不影响使用

6、服务提供者全部宕掉后,服务消费者应用将无法使用,并无限次重连等待服务提供者恢复

伸缩性

1、注册中心为对等集群,可动态增加机器部署实例,所有客户端将自动发现新的注册中心

2、服务提供者无状态,可动态增加机器部署实例,注册中心将推送新的服务提供者信息给消费者

dubbo 框架设计

dubbo 框架设计 dubbo官网讲解的非常明白,这里就不在赘述了,点击 dubbo 框架设计 可以查看

dubbo 源码

从 https://github.com/apache/dubbo 下载 dubbo源码,导入到 idea 中,源码总体结构如下:

dubbo-common(公共逻辑模块) :包括 Util 类和通用模型

dubbo-remoting(远程通讯模块):相当于 Dubbo 协议的实现,如果 RPC 用 RMI协议则不需要使用此包

dubbo-rpc(远程调用模块):抽象各种协议,以及动态代理,只包含一对一的调用,不关心集群的管理

dubbo-cluster(集群模块):将多个服务提供方伪装为一个提供方,包括:负载均衡, 容错,路由等,集群的地址列表可以是静态配置的,也可以是由注册中心下发

dubbo-registry(注册中心模块):基于注册中心下发地址的集群方式,以及对各种注册中心的抽象

dubbo-monitor(监控模块):统计服务调用次数,调用时间的,调用链跟踪的服务

dubbo-config(配置模块):是 Dubbo 对外的 API,用户通过 Config 使用Dubbo,隐藏 Dubbo 所有细节

dubbo-container(容器模块):是一个 Standlone 的容器,以简单的 Main 加载 Spring 启动,因为服务通常不需要 Tomcat/JBoss 等 Web 容器的特性,没必要用 Web 容器去加载服务

dubbo-serialization(序列化模块):数据序列化模板,默认是 Hessian2Serialization 序列化方式

参考:

https://dubbo.apache.org/zh-cn/docs/user/preface/architecture.html

https://dubbo.apache.org/zh-cn/docs/dev/design.html

猜你喜欢

转载自blog.csdn.net/ywlmsm1224811/article/details/102563031