我是靠谱客的博主 刻苦红酒,最近开发中收集的这篇文章主要介绍Dubbo的SPI,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

从零开始学Dubbo-基础篇-SPI使用

SPI 全称为 (Service Provider Interface) ,是JDK内置的一种服务提供发现机制。
目前有不少框架用它来做服务的扩展发现,简单来说,它就是一种动态替换发现的机制。
使用SPI机制的优势是实现解耦,使得第三方服务模块的装配控制逻辑与调用者的业务代码分离。

SPI遵循如下约定:
1、当服务提供者提供了接口的一种具体实现后,在META-INF/services目录下创建一个以“接口全限定名”为命名的文件,内容为实现类的全限定名;
2、接口实现类所在的jar包放在主程序的classpath中;
3、主程序通过java.util.ServiceLoader动态装载实现模块,它通过扫描META-INF/services目录下的配置文件找到实现类的全限定名,把类加载到JVM;
4、SPI的实现类必须携带一个无参构造方法;

dubbo为什么要写自己的SPI
1、JDK 标准的 SPI 会一次性实例化扩展点所有实现,如果有扩展实现初始化很耗时,但如果没用上也加 载,会很浪费资源,因此dubbo实现了按需加载
2、如果有扩展点加载失败,则所有扩展点无法使用
3、提供了对扩展点包装的功能(Adaptive),并且还支持通过set的方式对其他的扩展点进行注入

最后

以上就是刻苦红酒为你收集整理的Dubbo的SPI的全部内容,希望文章能够帮你解决Dubbo的SPI所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(52)

评论列表共有 0 条评论

立即
投稿
返回
顶部