dubbo-4:Dubbo中的SPI(基础)

10 篇文章 1 订阅

dubbo中大量的使用了SPI来作为扩展点,通过实现同一接口的前提下,可以进行定制自己的实现类。

比如比较常见的协议,负载均衡,都可以通过SPI的方式进行定制化,自己扩展。

Dubbo中已经存在的所有已经实现好的扩展点如下:
在这里插入图片描述

Dubbo中默认提供的负载均衡策略如下:
在这里插入图片描述
代码实现:
三个module

  • 服务接口项目api:dubbo-spi-demo-api
  • 服务实现项目impl:dubbo-spi-demo-impl
  • 主项目main:dubbo-spi-demo-main

在这里插入图片描述

一、dubbo-spi-demo-api

1、pom

 <dependency>
     <groupId>org.apache.dubbo</groupId>
     <artifactId>dubbo</artifactId>
     <version>2.7.5</version>
 </dependency>

2、创建接口

package com.lagou.service;

import org.apache.dubbo.common.URL;
import org.apache.dubbo.common.extension.Adaptive;
import org.apache.dubbo.common.extension.SPI;

@SPI
public interface HelloService {
    String sayHello();
}

二、dubbo-spi-demo-impl

1、引用api

  <dependencies>
        <dependency>
            <groupId>com.lagou</groupId>
            <artifactId>dubbo-spi-demo-api</artifactId>
            <version>1.0-SNAPSHOT</version>
        </dependency>
    </dependencies>

2、定义两个实现类

package com.lagou.service.impl;

import com.lagou.service.HelloService;

public class DogHelloService implements HelloService {
    @Override
    public String sayHello() {
        return "wang wang";
    }
}

package com.lagou.service.impl;

import com.lagou.service.HelloService;


public class HumanHelloService implements HelloService {
    @Override
    public String sayHello() {
        return "hello 你好";
    }
}

3、配置

在resources\META-INF\dubbo下创建文件
【com.lagou.service.HelloService】

human=com.lagou.service.impl.HumanHelloService
dog=com.lagou.service.impl.DogHelloService

在这里插入图片描述

三、dubbo-spi-demo-main

1、引用上面两个demo

<dependencies>
        <dependency>
            <groupId>com.lagou</groupId>
            <artifactId>dubbo-spi-demo-api</artifactId>
            <version>1.0-SNAPSHOT</version>
        </dependency>
        <dependency>
            <groupId>com.lagou</groupId>
            <artifactId>dubbo-spi-demo-impl</artifactId>
            <version>1.0-SNAPSHOT</version>
        </dependency>
    </dependencies>

2、测试

package com.lagou;

import com.lagou.service.HelloService;
import org.apache.dubbo.common.extension.ExtensionLoader;

import java.util.Set;

public class DubboSpiMain {
    public static void main(String[] args) {

        ExtensionLoader<HelloService> extensionLoader=ExtensionLoader.getExtensionLoader(HelloService.class);
        Set<String> supportedExtensions = extensionLoader.getSupportedExtensions();

        for (String extension : supportedExtensions) {
            String result = extensionLoader.getExtension(extension).sayHello();
            System.out.println(result);
        }
    }
}

在这里插入图片描述

四、dubbo自己做SPI的目的

  1. JDK 标准的 SPI 会一次性实例化扩展点所有实现,如果有扩展实现初始化很耗时,但没用上,这种情况也会加载,很浪费资源
  2. 如果有扩展点加载失败,则所有扩展点无法使用
  3. 提供了对扩展点包装的功能(Adaptive),并且还支持通过set的方式对其他的扩展点进行注入
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值