46

Java SPI (Service Provider Interface) 原理、设计及源码解析(一)

 4 years ago
source link: https://mp.weixin.qq.com/s?__biz=MzUzNjAxODg4MQ%3D%3D&%3Bmid=2247484399&%3Bidx=1&%3Bsn=c615d1321873f31cf937b022e2704c3f&%3Bchksm=fafde941cd8a605744365042b4c417b3d018729313f04710fe09c2f82aec4f4de549a1a
Go to the source link to view the article. You can view the picture content, updated content and better typesetting reading experience. If the link is broken, please click the button below to view the snapshot at that time.

背景

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

概念

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

谁在用

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

怎么判断有没有用

VRfYn2e.jpg!web

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

怎么用

NNVfqe2.jpg!web

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

1>定义一个服务端

step1:实现服务接口

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

ZJ7jAbf.jpg!web

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

mM7BZ3q.jpg!web

2>定义一个客户端

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

MzEBruz.jpg!web

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

bqmAFj3.jpg!web

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

原理

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

nEbI73Z.jpg!web

设计

依赖接口而不是实现,灵活可插拔。

相关阅读


About Joyk


Aggregate valuable and interesting links.
Joyk means Joy of geeK