dubbo种spi机制

 Dubbo是一个分布式服务框架,致力于提供高性能和透明化的RPC远程服务调用方案,以及SOA服务治理方案。简单的说,dubbo就是个服务框架,如果没有分布式的需求,其实是不需要用的,只有在分布式的时候,才有dubbo这样的分布式服务框架的需求,并且本质上是个服务调用的东东,说白了就是个远程服务调用的分布式框架(告别Web Service模式中的WSdl,以服务者与消费者的方式在dubbo上注册)

其核心部分包含:

1. 远程通讯: 提供对多种基于长连接的NIO框架抽象封装,包括多种线程模型,序列化,以及“请求-响应”模式的信息交换方式。

2. 集群容错: 提供基于接口方法的透明远程过程调用,包括多协议支持,以及软负载均衡,失败容错,地址路由,动态配置等集群支持。

3. 自动发现: 基于注册中心目录服务,使服务消费方能动态的查找服务提供方,使地址透明,使服务提供方可以平滑增加或减少机器。

核心的spi 扩展机制在 resource文件下新建目录 

 

dubbo种spi机制_第1张图片

 

测试类 

 

dubbo种spi机制_第2张图片

原理分析 : 扩展器ExtensionLoader 类 

 

dubbo种spi机制_第3张图片

获取扩展类 new ExtensionLoader() 调用getAdaptiveExtension() 方法

 

dubbo种spi机制_第4张图片

没有就调用 createAdaptiveExtension()方法 创建当前实例

 

dubbo种spi机制_第5张图片

 

dubbo种spi机制_第6张图片

生成新的对象 Adaptive 作用在方法上 自适应创建 作用在类上 用当前类

你可能感兴趣的:(dubbo种spi机制)