我是靠谱客的博主 天真小鸭子,最近开发中收集的这篇文章主要介绍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的目的
- JDK 标准的 SPI 会一次性实例化扩展点所有实现,如果有扩展实现初始化很耗时,但没用上,这种情况也会加载,很浪费资源
- 如果有扩展点加载失败,则所有扩展点无法使用
- 提供了对扩展点包装的功能(
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的目的所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复