1.dubbo源码解析

      dubbo-common 模块: Dubbo 的一个公共模块

        dubbo-remoting 模块: Dubbo 远程通信模块,子模块依赖各种开源组件实现远程通信,dubbo-remoting-api 子模块中定义该模块的抽象概念,在其他子模块中依赖其他开源组件进行实现,例如,dubbo-remoting-netty4 子模块依赖 Netty 4 实现远程通信,dubbo-remoting-zookeeper 通过 Apache Curator 实现与 ZooKeeper 集群的交互。

        dubbo-rpc 模块: Dubbo 中对远程调用协议进行抽象的模块,其中抽象了各种协议,依赖于 dubbo-remoting 模块的远程调用功能。dubbo-rpc-api 子模块是核心抽象,其他子模块是针对具体协议的实现,例如,dubbo-rpc-dubbo 子模块是对 Dubbo 协议的实现,依赖了 dubbo-remoting-netty4 等 dubbo-remoting 子模块。 dubbo-rpc 模块的实现中只包含一对一的调用,不关心集群的相关内容。

        dubbo-cluster 模块: Dubbo 负责管理集群的模块,提供负载均衡、容错、路由等一系列集群相关功能,最终的目的是将多个 Provider 伪装为一个 Provider,Consumer 就可以像调用一个 Provider 那样调用 Provider 集群。

        dubbo-registry 模块: Dubbo 负责与多种开源注册中心进行交互的模块,提供注册中心的能力。dubbo-registry-api 子模块是顶层抽象,其他子模块是针对具体开源注册中心组件的具体实现,例如,dubbo-registry-zookeeper 子模块是 Dubbo 接入 ZooKeeper 的具体实现。

   dubbo-monitor 模块: Dubbo 的监控模块,主要用于统计服务调用次数、调用时间以及实现调用链跟踪的服务。

   dubbo-config 模块: Dubbo 对外暴露的配置都是由该模块进行解析的。例如,dubbo-config-api 子模块负责处理 API 方式使用时的相关配置,dubbo-config-spring 子模块负责处理与 Spring 集成使用时的相关配置方式。dubbo-config 模块,用户只需要了解 Dubbo 配置的规则即可,无须了解 Dubbo 内部的细节。

   dubbo-configcenter 模块: Dubbo 的动态配置模块,主要负责外部化配置以及服务治理规则的存储与通知,提供多个子模块用来接入多种开源的服务发现组件。

  

posted on 2022-08-28 16:11  溪水静幽  阅读(136)  评论(0)    收藏  举报