sxyizhiren 2019-05-16
背景
团队内部轮流技术分享,其他人都是分享源码,我每次都是设计和架构,感觉自己太特立独行。这次我要合群点,分享点源码。
概念
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的源码。
设计
依赖接口而不是实现,灵活可插拔。