zoukankan      html  css  js  c++  java
  • JAVA SPI(Service Provider Interface)原理、设计及源码解析(其一)

    背景

    团队内部轮流技术分享,其他人都是分享源码,我每次都是设计和架构,感觉自己太特立独行。这次我要合群点,分享点源码。

    概念

    Service Provider Interface:服务提供方接口。是一种JVM层面的服务注册发现机制。

    谁在用

    jdbc源码里我见过SPI、Dubbo源码里我见过SPI、Eleasticsearch源码里我见过SPI……在基础服务中使用占比很高。

    怎么判断有没有用

    如上图,META-INF/services下面能看到长的很像类的完全限定名,就八九不离十了。

    怎么用

     

    服务注册发现机制一个简陋的实现就是找到一个满足需求的服务就返回。如果调用第一个服务出了异常崩溃了,就接着查找下一个。SPI最简单使用也是如此。

    1>定义一个服务端

    step1:实现服务接口

    step2:在META-INF/services下创建接口的完全限定名为文件名的文件,编码为utf8。

     step3:在文件内协商接口的实现类的完全限定名,可以是一个,也可以是一个列表

    2>定义一个客户端

    step1:通过java.util.ServiceLoader.load方法来加载服务的实现(框架里也可以用@SPI注解)

    step2:基于拿到的数据自己做注册发现

    这也是在DriverManager中的一个方法,实现了找到一个能用的就返回。

    原理

    服务端很好理解,就是一个定义。客户端来看看ServiceLoader的源码。

     

  • 相关阅读:
    export和import实现模块化
    Net Core
    DockerCon 2016
    NET Core 构成体系
    Cloud Engine
    JVM内存结构
    Signalr
    Rabbit.Rpc
    遍历指定包名下所有的类(支持jar)(转)
    httpd的简单配置(转)
  • 原文地址:https://www.cnblogs.com/xiexj/p/10739773.html
Copyright © 2011-2022 走看看