我是靠谱客的博主 天真小鸭子,最近开发中收集的这篇文章主要介绍dubbo-4:Dubbo中的SPI(基础)一、dubbo-spi-demo-api二、dubbo-spi-demo-impl三、dubbo-spi-demo-main四、dubbo自己做SPI的目的,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

目录

  • 一、dubbo-spi-demo-api
    • 1、pom
    • 2、创建接口
  • 二、dubbo-spi-demo-impl
    • 1、引用api
    • 2、定义两个实现类
    • 3、配置
  • 三、dubbo-spi-demo-main
    • 1、引用上面两个demo
    • 2、测试
  • 四、dubbo自己做SPI的目的

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、配置

在resourcesMETA-INFdubbo下创建文件
【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的方式对其他的扩展点进行注入

最后

以上就是天真小鸭子为你收集整理的dubbo-4:Dubbo中的SPI(基础)一、dubbo-spi-demo-api二、dubbo-spi-demo-impl三、dubbo-spi-demo-main四、dubbo自己做SPI的目的的全部内容,希望文章能够帮你解决dubbo-4:Dubbo中的SPI(基础)一、dubbo-spi-demo-api二、dubbo-spi-demo-impl三、dubbo-spi-demo-main四、dubbo自己做SPI的目的所遇到的程序开发问题。

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

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

评论列表共有 0 条评论

立即
投稿
返回
顶部