JAVA SPI(Service Provider Interface)原理、设…

2019-04-25 06:56:25来源:博客园 阅读 ()

新老客户大回馈,云服务器低至5折

背景

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

概念

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的源码。

设计

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

 

 

相关阅读

面试官说:你真的不是不优秀只是不合适

不够聪明所以选择工程?

面试官视角看面试

知名互联网公司需要什么样的人才

服务设计要解决的问题

 

 

 


原文链接:https://www.cnblogs.com/xiexj/p/10739773.html
如有疑问请与原作者联系

标签:

版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有

上一篇:T5大牛带你解析:如何实现分布式技术

下一篇:注解ConfigurationProperties注入yml配置文件中的数据