Dubbo通用模块,定义了业务无关的工具类例如io处理、日志处理、配置处理、类处理等等 *** 作,以及对于线程池的扩展,二进制编码处理,class编译处理,json数据处理,数据持久化接口处理等等。
1.2、dubbo-rpc-api 分布式服务调用框架RPC的核心基本实现,可以看到其中提供了很多的RPC抽象类、接口和实现类,包括服务发布,服务调用,远程调用,RPC调用网络协议,RPC条用监听和过滤器等功能。提供了默认的基于Dubbo写协议的实现,还提供了其他的协议的实现,灵活通用,可以满足大多数项目的使用要求。
1.3、dubbo-registry-api 作为注册中心的核心接口重要组成部分,在DubboRPC中有两个角色Consumer和Provider,这个模块的主要功能就是实现服务的注册功能,例如我们常用的服务注册中心Zookeeper的支持还有使用Redis作为注册中心的支持
1.4、dubbo-remoting-api 这个模块作为Dubbo远程路由通讯的模块,实现的主要功能就是远程通讯,consumer要调用provider的远程方法就必须通过网络远程调用,这个模块定义了远程传输器、终端(endpoint)、客户端、服务端、编码器解码器、数据交换、缓冲区、通讯异常等核心接口,还提供了远程网络访问的抽象。例如Netty等。
1.5、dubbo-monitor-api 主要的监控模块,提供了服务调度的各种信息,例如调用时间,调用结果等,在控制中心通过收集调用信息,对于收集到的信息进行统计分析。最终可以实现对于各种调用的维护功能。
1.6、dubbo-container-api dubbo支持服务运行的容器,定义启动列表包含应用程序的入口,定义容器的接口Container,包含启动和停止的方法,内置了很多的容器实现例如spring、jetty等等。
1.7、dubbo-config-api 作为Dubbo的配置模块,通过它的配置和组装将dubbo组件的各个模块组合在一起实现分布式服务框架,通过配置可以实现符合开发者要求的配置,提供例如服务发布配置、方法发布配置、服务消费配置、应用程序配置、注册中心配置、协议配置、监控配置等等,还有一系列关于spring的配置。
1.8、dubbo-cluster dubbo集群实现,支持远程服务的集群,支持多种服务集群的调用。并且支持目录服务、注册中心就是一个典型的目录服务实现,支持负载均衡,具体的其他功能在分析源码的时候在进行详细的分析。
2、架构分析从上到下可以分为十层,下面就来分析一下各个层级的作用。
2.1、Service层表示服务层,也就是说是表示服务的提供者以及服务消费者,在微服务架构中无论是服务提供者还是服务消费者在整个的服务治理体系中都是被看作是一个服务存在。这里通过实现接口或者继承接口的方式进行服务的调用配置,也就是在服务调用的过程中所有继承了某个接口的的服务类就可以向外提供服务。
2.2、Config配置层对外配置的接口,这个功能是以ServiceConfig、ReferenceConfig类为中心,可以提供直接的初始化的配置,也可以通过Spring框架来解析对应的配置文件生成配置类。
2.3、Proxy服务代理层服务接口代理,主要使用了代理模式,在实现远程服务调用的时候不至于直接 *** 作原始对象,生成服务器端的客户端Stub和服务气短的Skeleton,这个代理层以ServiceProxy为中心,通过ProxyFactory进行扩展。
2.4、Registry注册中心封装服务地址以及服务的注册和发现。以服务为中心,拓展接口是RegistryFactory,Registry,RegistryService。当然还提供了RegistryDirectory,RegistryProtocol等实现类。
2.5、Cluster路由层封装多个服务提供者的路由以及负载均衡信息,并且桥接了注册中心,以Invoker为中心,扩展接口为Cluster、Directory、Router、LoadBalance
2.6、Monitor监控RPC 调用次数和调用时间监控,以Statistics为中心,扩展接口为MonitorFactory、Monitor、MonitorService
2.7、Protocol远程调用层封装了RPC调用,以Invocation,Result 为中心,扩展的接口为Protocol,Invoker,Exporter等
2.8、exchange信息交换层封装请求响应模式,同步与异步之间的转换,以Request、Response为中心,提供了Exchange、ExchangeChannel、ExchangeClient、ExchangeServer等接口以及实现类。
2.9、Transport网络传输层对于mina和Netty接口的统一抽象,以Message为中心,扩展接口为Channel,Transporter,Client,Server,Codec。
2.10、Serialize数据序列化层提供了一些数据序列化可复用的工具,扩展接口为Serialization,ObjectInput,ObjectOutput,ThreadPool。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)