tuzhenxian / Extension

一个通过SPI机制,实现架构扩展性的框架

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool

这是什么

相对于普通spi,你只能调用同jvm中的spi实现,本框架支持对远程spi的调用。

架构图

调用逻辑图

如何使用

maven依赖

<dependency>
    <groupId>com.cmt</groupId>
    <artifactId>extension-core</artifactId>
    <version>1.1.0-SNAPSHOT</version>
</dependency>

spi消费者

  1. 增加spring配置
@Bean
public SpiConsumerBootStrap spiBootStrap() {
    SpiConsumerBootStrap spiBootStrap = new SpiConsumerBootStrap();
    spiBootStrap.setAppName("test");
    return spiBootStrap;
}

appName需要和控制台一致

  1. 标记SPI接口 给需要作为扩展点的接口加上SPI注解
@SPI
public interface IHelloService {
  String hello();
}
  1. 注入spi
@Resource(name = "IHelloService")
IHelloService helloService;

使用spring的@Resource注解,name和接口名一致

4.注册本地默认实现

//@Extension(bizCode = DEFAULT_BIZ_CODE,invokeMethod = SpiTypeEnum.LOCAL)
@Extension
public class DefaultHelloServiceImpl implements IHelloService {
    public String hello() {
        return "default hello";
    }
}

当找不到bizCode对应的spi时,调用spi默认实现。

  1. 注册spi本地实现(可选)
@Extension(bizCode = "d",invokeMethod = SpiTypeEnum.LOCAL)
public class LocalHelloServiceImpl implements IHelloService {
    public String hello() {
        return "local";
    }
}
  1. 调用 在该spi在被调用前,需要通过BusinessContext设置bizCode才能路由到正确的spi实现
BusinessContext.setBizCode("a");
testService.hello();

spi提供者

  1. 增加spring配置
@Bean
public  SpiProviderBootStrap businessBootStrap() {
    return new SpiProviderBootStrap();
}
  1. 提供spi接口远程实现
@Extension(bizCode = "a", invokeMethod = SpiTypeEnum.DUBBO)
public class AHelloServiceImpl implements IHelloService{
    public String hello() {
        return "HelloA";
    }
}

配置admin控制台

为了让spi消费者能够正常消费远程/本地spi,需要在admin控制台注册你的spi实现 如何使用

示例

见源码extension-demo项目 使用步骤:

  1. 本地创建数据库,脚本见release-note项目
  2. 打包Extension项目,命令如下 mvn clean package -DskipTests=true
  3. 启动extension-bootstrap项目 2.1 访问本地的http://localhost:8080/static/index.html 2.2 登录系统(管理员账号见t_user表) 2.3 打开应用管理界面去创建应用,应用名称设置为test 2.4 打开spi管理界面,为test应用创建spi,spi的接口名称为spi-interface项目下的IHelloService接口全路径(com.cmt.extension.spi.IHelloService) SPI的bizCode属性见IHelloService接口所有实现类,按照与实现类上的@Extension注解的bizCode属性一致即可
  4. 启动zookeeper。若本地未按照zookeeper可以启动zookeeper-server项目的内嵌zookeeper
  5. 启动provider项目
  6. 运行consumer项目下的ApplicationContextHolderTest类。
  7. 可以自定义接口,只要按照IHelloService一样的到spi管理页面添加一下即可。

About

一个通过SPI机制,实现架构扩展性的框架


Languages

Language:JavaScript 50.9%Language:Java 41.8%Language:CSS 3.5%Language:HTML 1.9%Language:PLpgSQL 1.3%Language:Groovy 0.6%