dubbo SPI(Service Provider Interface)

1、演示案例

Github: dubbo-demo-spi

JDK ServiceLoader示例

ServiceLoaderMain类:ServiceLoader的测试入口。
ServiceLoaderInterface接口:定义一个接口,具体实现定义在resources/META-INF/services/com.alibaba.dubbo.demo.ServiceLoaderInterface目录下。

Dubbo SPI示例

SPIMain类:SPI的测试入口。
SPIService接口:定义一个@SPI接口,具体实现定义在resources/META-INF/dubbo/internal/com.alibaba.dubbo.demo.SPIService目录下。

2、相关注解

@SPI

描述:注解在类上,用于定义一个接口。
案例:Transporter接口使用@SPI(“netty”)注解,它的实现定义在resources/META-INF/dubbo/internal/com.alibaba.dubbo.remoting.Transporter目录下。

@Adaptive

描述:注解在类上时,可以通过ExtensionLoader#getAdaptiveExtension()获得实例对象;注解在方法时,通过参数决定实现类。

@Activate

描述:注解在类上,当group参数匹配时,则激活该实现。
案例:Filter接口使用@SPI注解,它的实现类ActiveLimitFilter则使用@Activate注解,当group="consumer"时激活该过滤器。

3、核心类:ExtensionLoader

  • ExtensionLoader#getExtension(String):通过name获取实现类对象。
  • ExtensionLoader#getAdaptiveExtension():获取实现类中含有@Adaptive注解的实现类对象。
  • ExtensionLoader#injectExtension(T):使用依赖注入注入对象。
  • ExtensionLoader#createAdaptiveExtensionClassCode():当方法上有@Adaptive注解时,需要为扩展点接口自动生成实现类字符串。
  • ExtensionLoader#getActivateExtension(URL url, String key, String group):筛选含有@Activate注解,并且group属性匹配的实现类对象。

猜你喜欢

转载自blog.csdn.net/fomeiherz/article/details/104468157