理解SPI

Posted dyg0826

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了理解SPI相关的知识,希望对你有一定的参考价值。

     SPI 全称为 Service Provider Interface,是一种服务发现机制。SPI 的本质是将接口实现类的全限定名配置在文件中,并由服务加载器读取配置文件,加载实现类。这样可以在运行时,动态为接口替换实现类。

    Dubbo 并未使用 Java 原生的 SPI 机制,而是对其进行了增强,使其能够更好的满足需求。在 Dubbo 中,SPI 是一个非常重要的模块。基于 SPI,我们可以很容易的对 Dubbo 进行拓展。如果大家想要学习 Dubbo 的源码,SPI 机制务必弄懂。接下来,我们先来了解一下 Java SPI 与 Dubbo SPI 的用法,然后再来分析 Dubbo SPI 的源码。

   1.0 Java SPI 示例

   

//定义接口
public interface SpiInterface
{ void sayHello(); } 

//实现类
public class SpiImpl01 implements SpiInterface {
@Override
public void sayHello() {
System.out.println("Hello, I am SpiImpl01.");
}
}
public class SpiImpl02 implements SpiInterface{
@Override
public void sayHello() {
System.out.println("Hello, I am SpiImpl02.");
}
}

   META-INF/services 文件夹下创建一个文件,名称为Spi的全限定名 接口路径

   文件内容:

com.demo.javaSpi.SpiImpl01
com.demo.javaSpi.SpiImpl02
public class JavaSPITest {

    @Test
    public void sayHello() throws Exception {
        ServiceLoader<SpiInterface> serviceLoader =ServiceLoader.load(SpiInterface.class); 
System.out.println(
"Java SPI");
serviceLoader.forEach(Spi::sayHello);
} }

结果:技术图片

       2.0 Dubbo SPI 示例

      SpiInterface接口加@SPI 注解

 

public class DubboSpiTest {
    @Test
    public void sayHello() throws Exception {
        ExtensionLoader<SpiInterface> extensionLoader = ExtensionLoader.getExtensionLoader(SpiInterface.class);
        SpiInterface spiImpl01 = extensionLoader.getExtension("spiImpl01");
        spiImpl01.sayHello();
        SpiInterface spiImpl02 = extensionLoader.getExtension("spiImpl02");
        spiImpl02.sayHello();
    }
}

结果:技术图片

Dubbo SPI 除了支持按需加载接口实现类,还增加了 IOC 和 AOP 等特性

 3.0 Dubbo SPI 源码分析

  待续

















以上是关于理解SPI的主要内容,如果未能解决你的问题,请参考以下文章

SPI通讯协议怎么理解呢。

金蝶handler中 collection 代码片段理解

SPI总线协议理解

Java SPI 机制源码级深度理解

调用模板化成员函数:帮助我理解另一个 *** 帖子中的代码片段

如何理解这段代码片段中的两对括号?