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的源码。
设计
依赖接口而不是实现,灵活可插拔。
相关推荐
瓜牛呱呱 2020-11-12
柳木木的IT 2020-11-04
yifouhu 2020-11-02
lei0 2020-11-02
源码zanqunet 2020-10-28
源码zanqunet 2020-10-26
一叶梧桐 2020-10-14
码代码的陈同学 2020-10-14
lukezhong 2020-10-14
lzzyok 2020-10-10
anchongnanzi 2020-09-21
clh0 2020-09-18
changcongying 2020-09-17
星辰大海的路上 2020-09-13
abfdada 2020-08-26
mzy000 2020-08-24
shenlanse 2020-08-18
zhujiangtaotaise 2020-08-18
xiemanR 2020-08-17