Fork me on GitHub

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

背景

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

概念

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

谁在用

jdbc源码里我见过SPI、Dubbo源码里我见过SPI、Eleasticsearch源码里我见过SPI……在基础服务中使用占?#32676;?#39640;。

怎么判断有没有用

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

怎么用

 

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

1>定义一个服务端

step1:实现服务接口

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

 

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

2>定义一个客户端

step1?#21644;?#36807;java.util.ServiceLoader.load方法来加载服务的实现(框架里?#37096;?#20197;用@SPI注解)

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

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

原理

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

 

 

 

posted @ 2019-04-24 10:17 编程一生 阅读(...) 评论(...) 编辑 收藏
耐克篮球多少钱
国标麻将 二八杠二八杠 3d试机号和开机号今天的 3d过滤缩水工具彩吧助手 11选5组三技巧 精彩万分两码中特 搜狐彩票pk10 羽毛球中国公开赛时间 安徽11选5遗漏 英超视频 香港六合彩书籍 淘宝彩票快3群 体彩四川金7乐秘诀 .一码中特 山西11选5规律